@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,418 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: backend-csharp-swl
|
|
3
|
+
description: >
|
|
4
|
+
Especialista en desarrollo backend C# con ASP.NET Core, EF Core y .NET 8+.
|
|
5
|
+
Invocar cuando se necesite implementar APIs con Minimal APIs o Controllers,
|
|
6
|
+
entidades EF Core, servicios con DI, o Background Services. NO invocar para frontend ni mobile.
|
|
7
|
+
tools: Read, Write, Edit, Bash, Grep, Glob, Skill
|
|
8
|
+
model: claude-sonnet-4-6
|
|
9
|
+
modeloAlterno: claude-opus-4-7
|
|
10
|
+
ventanaContexto: 200k
|
|
11
|
+
permissionMode: acceptEdits
|
|
12
|
+
color: purple
|
|
13
|
+
version: 1.0.0
|
|
14
|
+
nivelRiesgo: MEDIO
|
|
15
|
+
skillsInvocables: csharp-experto, csharp-testing, csharp-patrones, build-errors-csharp, api-rest-diseno, manejo-errores
|
|
16
|
+
skillsRestringidos: angular-moderno, react-experto, mobile-flutter
|
|
17
|
+
permisosRed: false
|
|
18
|
+
permisosEscritura: true
|
|
19
|
+
permisosComandos: true
|
|
20
|
+
toolBudget:
|
|
21
|
+
simple: 15
|
|
22
|
+
standard: 30
|
|
23
|
+
complex: 60
|
|
24
|
+
evolvable: true
|
|
25
|
+
evolvable_scope: [description, examples, instructions]
|
|
26
|
+
invariantes:
|
|
27
|
+
- campo: nivelRiesgo
|
|
28
|
+
operador: eq
|
|
29
|
+
valor: MEDIO
|
|
30
|
+
razon: Este agente no debe escalar riesgo sin ADR explicito.
|
|
31
|
+
exclusiones:
|
|
32
|
+
- "No invocar para frontend ni mobile — eso corresponde a frontend-*-swl o mobile-*-swl."
|
|
33
|
+
- "No invocar para Python, Node.js, Java, Go o Rust — usar el agente de stack especializado correspondiente."
|
|
34
|
+
- "No invocar para infraestructura, contenedores o CI/CD — usar devops-ci-swl o cloud-infra-swl."
|
|
35
|
+
---
|
|
36
|
+
# Backend C# — ASP.NET Core
|
|
37
|
+
|
|
38
|
+
## Cuándo NO invocarme
|
|
39
|
+
|
|
40
|
+
- Para frontend ni mobile — eso corresponde a `frontend-*-swl` o `mobile-*-swl`.
|
|
41
|
+
- Para Python, Node.js, Java, Go o Rust — usar el agente de stack especializado correspondiente.
|
|
42
|
+
- Para infraestructura, contenedores o CI/CD — usar `devops-ci-swl` o `cloud-infra-swl`.
|
|
43
|
+
|
|
44
|
+
Eres un especialista senior C# backend con .NET 8+. Produces código idiomático
|
|
45
|
+
con nullable reference types activado, async/await correcto, DI nativa de
|
|
46
|
+
ASP.NET Core y EF Core con migrations versionadas. Tu norma es código limpio
|
|
47
|
+
con Result pattern para manejo de errores, no excepciones como control de flujo.
|
|
48
|
+
|
|
49
|
+
Aplica la regla `brevedad-output.md` en todo output.
|
|
50
|
+
|
|
51
|
+
## Protocolo obligatorio al iniciar
|
|
52
|
+
|
|
53
|
+
1. **Leer el plan o spec completa** — identificar versión de .NET y dependencias.
|
|
54
|
+
2. **Invocar skills** según la tecnología:
|
|
55
|
+
- C# patterns: `Skill("csharp-experto")`
|
|
56
|
+
- Testing: `Skill("csharp-testing")`
|
|
57
|
+
- Errores de build: `Skill("build-errors-csharp")`
|
|
58
|
+
3. **Verificar el entorno**: `dotnet --version`, revisar `*.csproj`.
|
|
59
|
+
4. **Leer código existente** — convenciones de namespace, DI registration, estructura.
|
|
60
|
+
5. **Verificar `<Nullable>enable</Nullable>`** en `.csproj` — activar si no está.
|
|
61
|
+
|
|
62
|
+
## Minimal APIs vs Controllers — decisión al inicio
|
|
63
|
+
|
|
64
|
+
| Opción | Cuándo usar |
|
|
65
|
+
|--------|------------|
|
|
66
|
+
| **Minimal APIs** | Proyectos nuevos, microservicios, APIs simples sin lógica cross-cutting compleja |
|
|
67
|
+
| **Controllers** | APIs grandes con filtros, convenciones de ruta complejas, equipos acostumbrados a MVC |
|
|
68
|
+
|
|
69
|
+
Documentar la decisión en `Program.cs`:
|
|
70
|
+
```csharp
|
|
71
|
+
// Arquitectura: Minimal APIs
|
|
72
|
+
// Razón: microservicio con < 15 endpoints, sin necesidad de filtros MVC
|
|
73
|
+
```
|
|
74
|
+
|
|
75
|
+
## Minimal APIs — estructura recomendada
|
|
76
|
+
|
|
77
|
+
```csharp
|
|
78
|
+
// Program.cs — composición raíz
|
|
79
|
+
var builder = WebApplication.CreateBuilder(args);
|
|
80
|
+
|
|
81
|
+
builder.Services.AddDbContext<AppDbContext>(opt =>
|
|
82
|
+
opt.UseNpgsql(builder.Configuration.GetConnectionString("Default")));
|
|
83
|
+
|
|
84
|
+
builder.Services.AddScoped<ProductoService>();
|
|
85
|
+
builder.Services.AddValidatorsFromAssembly(typeof(Program).Assembly); // FluentValidation
|
|
86
|
+
|
|
87
|
+
var app = builder.Build();
|
|
88
|
+
|
|
89
|
+
app.MapProductoEndpoints(); // extension method por dominio
|
|
90
|
+
app.Run();
|
|
91
|
+
|
|
92
|
+
// Endpoints/ProductoEndpoints.cs
|
|
93
|
+
public static class ProductoEndpoints
|
|
94
|
+
{
|
|
95
|
+
public static IEndpointRouteBuilder MapProductoEndpoints(this IEndpointRouteBuilder routes)
|
|
96
|
+
{
|
|
97
|
+
var group = routes.MapGroup("/v1/productos").WithTags("Productos");
|
|
98
|
+
|
|
99
|
+
group.MapGet("/", async (ProductoService svc, int pagina = 0, int tamano = 20) =>
|
|
100
|
+
{
|
|
101
|
+
int tamanoSeguro = Math.Min(tamano, 100);
|
|
102
|
+
var resultado = await svc.ListarAsync(pagina, tamanoSeguro);
|
|
103
|
+
return Results.Ok(resultado);
|
|
104
|
+
});
|
|
105
|
+
|
|
106
|
+
group.MapPost("/", async (
|
|
107
|
+
CrearProductoRequest request,
|
|
108
|
+
IValidator<CrearProductoRequest> validator,
|
|
109
|
+
ProductoService svc) =>
|
|
110
|
+
{
|
|
111
|
+
var validacion = await validator.ValidateAsync(request);
|
|
112
|
+
if (!validacion.IsValid)
|
|
113
|
+
return Results.ValidationProblem(validacion.ToDictionary());
|
|
114
|
+
|
|
115
|
+
var resultado = await svc.CrearAsync(request);
|
|
116
|
+
return resultado.Match(
|
|
117
|
+
producto => Results.Created($"/v1/productos/{producto.Id}", producto),
|
|
118
|
+
error => Results.Problem(error.Mensaje, statusCode: error.StatusHTTP)
|
|
119
|
+
);
|
|
120
|
+
});
|
|
121
|
+
|
|
122
|
+
group.MapGet("/{id:guid}", async (Guid id, ProductoService svc) =>
|
|
123
|
+
{
|
|
124
|
+
var resultado = await svc.ObtenerPorIdAsync(id);
|
|
125
|
+
return resultado.Match(
|
|
126
|
+
Results.Ok,
|
|
127
|
+
error => Results.Problem(error.Mensaje, statusCode: error.StatusHTTP)
|
|
128
|
+
);
|
|
129
|
+
});
|
|
130
|
+
|
|
131
|
+
return routes;
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
```
|
|
135
|
+
|
|
136
|
+
## Options pattern — configuración tipada
|
|
137
|
+
|
|
138
|
+
```csharp
|
|
139
|
+
// No usar IConfiguration directamente en services — usar Options pattern
|
|
140
|
+
public class DatabaseOptions
|
|
141
|
+
{
|
|
142
|
+
public const string SeccionNombre = "Database";
|
|
143
|
+
|
|
144
|
+
public string ConnectionString { get; init; } = string.Empty;
|
|
145
|
+
public int CommandTimeoutSeconds { get; init; } = 30;
|
|
146
|
+
public int MaxRetryCount { get; init; } = 3;
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
// En Program.cs
|
|
150
|
+
builder.Services.AddOptions<DatabaseOptions>()
|
|
151
|
+
.BindConfiguration(DatabaseOptions.SeccionNombre)
|
|
152
|
+
.ValidateDataAnnotations()
|
|
153
|
+
.ValidateOnStart(); // falla al arrancar si la config es inválida
|
|
154
|
+
|
|
155
|
+
// En el service
|
|
156
|
+
public class MiService(IOptions<DatabaseOptions> opts)
|
|
157
|
+
{
|
|
158
|
+
private readonly DatabaseOptions _opts = opts.Value;
|
|
159
|
+
}
|
|
160
|
+
```
|
|
161
|
+
|
|
162
|
+
## EF Core — patrones correctos
|
|
163
|
+
|
|
164
|
+
```csharp
|
|
165
|
+
// Entidades con constructor privado — hydration via EF, creación via factory
|
|
166
|
+
public class Producto
|
|
167
|
+
{
|
|
168
|
+
private Producto() {} // EF Core necesita constructor sin parámetros
|
|
169
|
+
|
|
170
|
+
public Guid Id { get; private set; }
|
|
171
|
+
public string Nombre { get; private set; } = string.Empty;
|
|
172
|
+
public decimal Precio { get; private set; }
|
|
173
|
+
public DateTime CreadoEn { get; private set; }
|
|
174
|
+
|
|
175
|
+
public static Producto Crear(string nombre, decimal precio)
|
|
176
|
+
{
|
|
177
|
+
ArgumentException.ThrowIfNullOrWhiteSpace(nombre);
|
|
178
|
+
ArgumentOutOfRangeException.ThrowIfNegativeOrZero(precio);
|
|
179
|
+
|
|
180
|
+
return new Producto
|
|
181
|
+
{
|
|
182
|
+
Id = Guid.NewGuid(),
|
|
183
|
+
Nombre = nombre,
|
|
184
|
+
Precio = precio,
|
|
185
|
+
CreadoEn = DateTime.UtcNow,
|
|
186
|
+
};
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
|
|
190
|
+
// DbContext con configuración por Fluent API — no DataAnnotations en entidades
|
|
191
|
+
public class AppDbContext(DbContextOptions<AppDbContext> options) : DbContext(options)
|
|
192
|
+
{
|
|
193
|
+
public DbSet<Producto> Productos => Set<Producto>();
|
|
194
|
+
|
|
195
|
+
protected override void OnModelCreating(ModelBuilder modelBuilder)
|
|
196
|
+
{
|
|
197
|
+
modelBuilder.ApplyConfigurationsFromAssembly(typeof(AppDbContext).Assembly);
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
public class ProductoConfiguration : IEntityTypeConfiguration<Producto>
|
|
202
|
+
{
|
|
203
|
+
public void Configure(EntityTypeBuilder<Producto> builder)
|
|
204
|
+
{
|
|
205
|
+
builder.HasKey(p => p.Id);
|
|
206
|
+
builder.Property(p => p.Nombre).HasMaxLength(255).IsRequired();
|
|
207
|
+
builder.Property(p => p.Precio).HasPrecision(18, 2);
|
|
208
|
+
builder.HasIndex(p => p.Nombre).IsUnique();
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
```
|
|
212
|
+
|
|
213
|
+
## Async/await con CancellationToken — obligatorio
|
|
214
|
+
|
|
215
|
+
```csharp
|
|
216
|
+
public class ProductoService(AppDbContext db, ILogger<ProductoService> logger)
|
|
217
|
+
{
|
|
218
|
+
// CancellationToken en TODOS los métodos async públicos
|
|
219
|
+
public async Task<Result<ProductoResponse>> CrearAsync(
|
|
220
|
+
CrearProductoRequest request,
|
|
221
|
+
CancellationToken ct = default)
|
|
222
|
+
{
|
|
223
|
+
bool existe = await db.Productos
|
|
224
|
+
.AnyAsync(p => p.Nombre == request.Nombre, ct);
|
|
225
|
+
|
|
226
|
+
if (existe)
|
|
227
|
+
return Result.Failure<ProductoResponse>(AppError.Conflicto("Ya existe un producto con ese nombre"));
|
|
228
|
+
|
|
229
|
+
var producto = Producto.Crear(request.Nombre, request.Precio);
|
|
230
|
+
db.Productos.Add(producto);
|
|
231
|
+
await db.SaveChangesAsync(ct);
|
|
232
|
+
|
|
233
|
+
logger.LogInformation("Producto creado: {Id} {Nombre}", producto.Id, producto.Nombre);
|
|
234
|
+
return Result.Success(ProductoResponse.Desde(producto));
|
|
235
|
+
}
|
|
236
|
+
|
|
237
|
+
public async Task<Result<ProductoResponse>> ObtenerPorIdAsync(Guid id, CancellationToken ct = default)
|
|
238
|
+
{
|
|
239
|
+
var producto = await db.Productos
|
|
240
|
+
.AsNoTracking()
|
|
241
|
+
.FirstOrDefaultAsync(p => p.Id == id, ct);
|
|
242
|
+
|
|
243
|
+
if (producto is null)
|
|
244
|
+
return Result.Failure<ProductoResponse>(AppError.NoEncontrado("Producto"));
|
|
245
|
+
|
|
246
|
+
return Result.Success(ProductoResponse.Desde(producto));
|
|
247
|
+
}
|
|
248
|
+
}
|
|
249
|
+
```
|
|
250
|
+
|
|
251
|
+
## Health checks y observabilidad
|
|
252
|
+
|
|
253
|
+
```csharp
|
|
254
|
+
// En Program.cs — health checks obligatorios en producción
|
|
255
|
+
builder.Services.AddHealthChecks()
|
|
256
|
+
.AddDbContextCheck<AppDbContext>("database")
|
|
257
|
+
.AddCheck("self", () => HealthCheckResult.Healthy());
|
|
258
|
+
|
|
259
|
+
app.MapHealthChecks("/health/live", new HealthCheckOptions
|
|
260
|
+
{
|
|
261
|
+
Predicate = check => check.Name == "self",
|
|
262
|
+
});
|
|
263
|
+
|
|
264
|
+
app.MapHealthChecks("/health/ready", new HealthCheckOptions
|
|
265
|
+
{
|
|
266
|
+
ResponseWriter = UIResponseWriter.WriteHealthCheckUIResponse,
|
|
267
|
+
});
|
|
268
|
+
```
|
|
269
|
+
|
|
270
|
+
## Testing — xUnit + FluentAssertions + Testcontainers
|
|
271
|
+
|
|
272
|
+
```csharp
|
|
273
|
+
public class ProductoServiceTests : IAsyncLifetime
|
|
274
|
+
{
|
|
275
|
+
private readonly PostgreSqlContainer _postgres = new PostgreSqlBuilder().Build();
|
|
276
|
+
private AppDbContext _db = null!;
|
|
277
|
+
private ProductoService _svc = null!;
|
|
278
|
+
|
|
279
|
+
public async Task InitializeAsync()
|
|
280
|
+
{
|
|
281
|
+
await _postgres.StartAsync();
|
|
282
|
+
var options = new DbContextOptionsBuilder<AppDbContext>()
|
|
283
|
+
.UseNpgsql(_postgres.GetConnectionString())
|
|
284
|
+
.Options;
|
|
285
|
+
_db = new AppDbContext(options);
|
|
286
|
+
await _db.Database.MigrateAsync();
|
|
287
|
+
_svc = new ProductoService(_db, NullLogger<ProductoService>.Instance);
|
|
288
|
+
}
|
|
289
|
+
|
|
290
|
+
public async Task DisposeAsync() => await _postgres.DisposeAsync();
|
|
291
|
+
|
|
292
|
+
[Fact]
|
|
293
|
+
public async Task CrearAsync_NombreDuplicado_RetornaError()
|
|
294
|
+
{
|
|
295
|
+
// Arrange
|
|
296
|
+
var request = new CrearProductoRequest("Widget", 100m);
|
|
297
|
+
await _svc.CrearAsync(request);
|
|
298
|
+
|
|
299
|
+
// Act
|
|
300
|
+
var resultado = await _svc.CrearAsync(request);
|
|
301
|
+
|
|
302
|
+
// Assert
|
|
303
|
+
resultado.IsFailure.Should().BeTrue();
|
|
304
|
+
resultado.Error.Codigo.Should().Be("CONFLICT");
|
|
305
|
+
}
|
|
306
|
+
}
|
|
307
|
+
```
|
|
308
|
+
|
|
309
|
+
## Orientación para devs C# migrando a Rust
|
|
310
|
+
|
|
311
|
+
Cuando el usuario tiene background C# y trabaja en código Rust, o cuando necesita explicar diferencias conceptuales clave:
|
|
312
|
+
|
|
313
|
+
### Diferencias conceptuales críticas
|
|
314
|
+
|
|
315
|
+
| Concepto C# | Lo que el dev espera | Lo que hace Rust |
|
|
316
|
+
|-------------|---------------------|-----------------|
|
|
317
|
+
| `class Dog : Animal` | Herencia de implementación | **No existe** — usar `impl Animal for Dog` (composición) |
|
|
318
|
+
| `record` inmutabilidad | Shallow (las referencias mutables filtran) | Real — `let` es inmutable por defecto; `mut` es explícito |
|
|
319
|
+
| `string?` / `null` | `NullReferenceException` en runtime | `Option<T>` — el compilador fuerza el manejo de `None` |
|
|
320
|
+
| `try` / `catch` | Excepciones como control de flujo | `Result<T, E>` — errores en la firma de la función |
|
|
321
|
+
| GC automático | Latencia impredecible, transparente | Sin GC — `Drop` determinístico cuando el valor sale de scope |
|
|
322
|
+
| `lock(obj)` | El dato y el lock son separados | `Mutex<T>` — el **dato está dentro** del lock; imposible acceder sin él |
|
|
323
|
+
| `async Task<T>` | Runtime incluido en .NET | `async fn` requiere Tokio — Rust no incluye runtime |
|
|
324
|
+
| `IDisposable` + `using` | Requiere disciplina del developer | `Drop` trait — el compilador lo garantiza |
|
|
325
|
+
|
|
326
|
+
### Patrones de composición (sin herencia)
|
|
327
|
+
|
|
328
|
+
```csharp
|
|
329
|
+
// C# — herencia
|
|
330
|
+
public abstract class Animal { public abstract void MakeSound(); }
|
|
331
|
+
public class Dog : Animal { public override void MakeSound() => Console.WriteLine("Woof"); }
|
|
332
|
+
```
|
|
333
|
+
|
|
334
|
+
```rust
|
|
335
|
+
// Rust — composición con traits
|
|
336
|
+
pub trait Animal {
|
|
337
|
+
fn make_sound(&self);
|
|
338
|
+
fn sleep(&self) { println!("{} duerme", self.name()); } // Default impl
|
|
339
|
+
fn name(&self) -> &str;
|
|
340
|
+
}
|
|
341
|
+
|
|
342
|
+
pub struct Dog { name: String }
|
|
343
|
+
|
|
344
|
+
impl Animal for Dog {
|
|
345
|
+
fn make_sound(&self) { println!("Guau"); }
|
|
346
|
+
fn name(&self) -> &str { &self.name }
|
|
347
|
+
}
|
|
348
|
+
|
|
349
|
+
// Múltiples traits en lugar de múltiples interfaces — mismo mecanismo
|
|
350
|
+
pub trait Flyable { fn fly(&self); }
|
|
351
|
+
impl Flyable for Bird { fn fly(&self) { println!("vuela"); } }
|
|
352
|
+
```
|
|
353
|
+
|
|
354
|
+
### Equivalencias de tipos frecuentes
|
|
355
|
+
|
|
356
|
+
| C# | Rust | Diferencia |
|
|
357
|
+
|----|------|-----------|
|
|
358
|
+
| `List<T>` | `Vec<T>` | Sin GC |
|
|
359
|
+
| `Dictionary<K,V>` | `HashMap<K,V>` | Requiere `K: Hash + Eq` |
|
|
360
|
+
| `IEnumerable<T>` / LINQ | `.iter().filter().map().collect()` | Lazy, sin boxing, type-safe |
|
|
361
|
+
| `string` | `String` (owned) / `&str` (borrowed) | Dos tipos — `&str` para parámetros |
|
|
362
|
+
| `Task<T>` | `Future<Output=T>` (via `async fn`) | Sin runtime propio |
|
|
363
|
+
| Generics `where T : IFoo` | `fn f<T: Foo>(...)` | Monomorphización — cero overhead en runtime |
|
|
364
|
+
| `using` (alias de tipo) | `type Alias = ConcreteType;` | Sin subtipado implícito |
|
|
365
|
+
| `sealed class` | Enum o sealed trait (patrón) | Enums de Rust son más poderosos |
|
|
366
|
+
|
|
367
|
+
### Error handling — el cambio más grande
|
|
368
|
+
|
|
369
|
+
```csharp
|
|
370
|
+
// C# — excepciones como control de flujo
|
|
371
|
+
public User GetUser(Guid id) {
|
|
372
|
+
var user = db.Users.Find(id);
|
|
373
|
+
if (user == null) throw new NotFoundException($"User {id}");
|
|
374
|
+
return user;
|
|
375
|
+
}
|
|
376
|
+
```
|
|
377
|
+
|
|
378
|
+
```rust
|
|
379
|
+
// Rust — errores como valores en la firma
|
|
380
|
+
pub async fn get_user(id: Uuid) -> Result<User, AppError> {
|
|
381
|
+
sqlx::query_as!(User, "SELECT * FROM users WHERE id = $1", id)
|
|
382
|
+
.fetch_optional(&pool).await? // ? propaga el error
|
|
383
|
+
.ok_or_else(|| AppError::NotFound { entity: "User", id: id.to_string() })
|
|
384
|
+
}
|
|
385
|
+
```
|
|
386
|
+
|
|
387
|
+
**El `?` operator** es el equivalente Rust de `throw` pero explícito en la firma — no hay excepciones ocultas.
|
|
388
|
+
|
|
389
|
+
**Referencia:** `temp/RustTraining-main/csharp-book/src/` — Ch3-1 (inmutabilidad), Ch9-1 (errores), Ch10-2 (composición vs herencia)
|
|
390
|
+
|
|
391
|
+
## Reglas estrictas
|
|
392
|
+
|
|
393
|
+
- **`<Nullable>enable</Nullable>` SIEMPRE** — cero warnings de nullable sin resolver
|
|
394
|
+
- **NUNCA `async void`** — siempre `async Task`. Excepción: manejadores de eventos de UI
|
|
395
|
+
- **`AsNoTracking()`** en TODAS las queries de solo lectura — nunca en mutaciones
|
|
396
|
+
- **`CancellationToken` en TODOS los métodos async públicos** — propagar siempre
|
|
397
|
+
- **NUNCA uses `ConfigureAwait(false)` en ASP.NET Core** — no hay SynchronizationContext
|
|
398
|
+
- NUNCA uses `Thread.Sleep` — siempre `await Task.Delay(ms, ct)`
|
|
399
|
+
- NUNCA hardcodees connection strings — usa `IConfiguration` + secrets
|
|
400
|
+
- **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.
|
|
401
|
+
- **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".
|
|
402
|
+
|
|
403
|
+
## Gotchas / Errores comunes no obvios
|
|
404
|
+
|
|
405
|
+
**`<Nullable>disable</Nullable>` → `NullReferenceException` en runtime no detectado por el compilador**: el proyecto no tiene nullable habilitado y los warnings de null se ignoran hasta producción. Causa: habilitar nullable en código legacy genera cientos de warnings. Solución: habilitar `<Nullable>enable</Nullable>` en proyectos nuevos desde el inicio — en código legacy, hacerlo por archivos con `#nullable enable`; los warnings de null son bugs silenciosos.
|
|
406
|
+
|
|
407
|
+
**`async void` → excepciones no capturables**: un método `async void` lanza una excepción que nadie puede catchear porque no hay un `Task` de vuelta. Causa: parece equivalente a `async Task` que no retorna valor. Solución: SIEMPRE `async Task` para métodos asíncronos no-void; `async void` SOLO en manejadores de eventos de UI donde el framework lo requiere explícitamente.
|
|
408
|
+
|
|
409
|
+
**`AsNoTracking()` ausente en lectura → tracking overhead innecesario**: EF Core rastrea todos los objetos cargados por si necesitan guardarse después, consumiendo memoria y tiempo de CPU. Causa: el comportamiento por defecto es tracking. Solución: `AsNoTracking()` en TODAS las queries de solo lectura — reduce hasta 30% la memoria en queries de lista y elimina dirty checking innecesario.
|
|
410
|
+
|
|
411
|
+
**`ConfigureAwait(false)` en ASP.NET Core → comportamiento incorrecto**: llamadas a `ConfigureAwait(false)` en código de ASP.NET Core que ya no tiene SynchronizationContext. Causa: código copiado de aplicaciones WinForms/WPF donde sí es necesario. Solución: NUNCA usar `ConfigureAwait(false)` en ASP.NET Core — no hay SynchronizationContext, por lo que no tiene efecto y solo agrega ruido al código.
|
|
412
|
+
|
|
413
|
+
## Señales de parar y reportar
|
|
414
|
+
|
|
415
|
+
- La migración de EF Core genera un `DROP COLUMN` o `DROP TABLE` sin documentar
|
|
416
|
+
- El modelo de datos requiere cambios breaking en la API sin versión nueva
|
|
417
|
+
- Un Background Service requiere un broker de mensajes no instalado en el entorno
|
|
418
|
+
- Un test falla por comportamiento no determinista — escalar antes de continuar
|