@nockdev/awf 6.2.0 → 6.2.2
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/.agent/build.yaml +3 -3
- package/.agent/config.yaml +21 -146
- package/.agent/core/AGENT_BEHAVIOR.md +86 -0
- package/.agent/core/AUDIT_POLICY.md +1 -1
- package/.agent/core/CACHE.md +1 -1
- package/.agent/core/COMMANDS.md +16 -7
- package/.agent/core/CUSTOMIZE.md +61 -3
- package/.agent/core/DATA_SAFETY.md +1 -1
- package/.agent/core/MEMORY_PATHS.yaml +2 -2
- package/.agent/core/PERMISSIONS.md +1 -1
- package/.agent/core/README.md +1 -1
- package/.agent/core/VERSION.yaml +18 -8
- package/.agent/core/{ACTIVE_MEMORY.yaml → archive/ACTIVE_MEMORY.yaml} +2 -2
- package/.agent/core/{CHECKPOINT.yaml → archive/CHECKPOINT.yaml} +2 -2
- package/.agent/core/{CLEANUP_ENGINE.yaml → archive/CLEANUP_ENGINE.yaml} +2 -2
- package/.agent/core/{CONTEXT_INJECTOR.yaml → archive/CONTEXT_INJECTOR.yaml} +2 -2
- package/.agent/core/{CONTEXT_LOADER.yaml → archive/CONTEXT_LOADER.yaml} +1 -1
- package/.agent/core/{CONTEXT_OPTIMIZATION.yaml → archive/CONTEXT_OPTIMIZATION.yaml} +1 -1
- package/.agent/core/{CONTEXT_PRIORITY.yaml → archive/CONTEXT_PRIORITY.yaml} +2 -2
- package/.agent/core/{FLOW_ENGINE.yaml → archive/FLOW_ENGINE.yaml} +1 -1
- package/.agent/core/{GRAPH_MEMORY.yaml → archive/GRAPH_MEMORY.yaml} +1 -1
- package/.agent/core/{HYBRID_ROUTER.yaml → archive/HYBRID_ROUTER.yaml} +1 -1
- package/.agent/core/{INTENT_DETECTION.yaml → archive/INTENT_DETECTION.yaml} +1 -1
- package/.agent/core/{MEMORY_CONSOLIDATION.yaml → archive/MEMORY_CONSOLIDATION.yaml} +3 -3
- package/.agent/core/{MEMORY_ENGINE.yaml → archive/MEMORY_ENGINE.yaml} +2 -2
- package/.agent/core/{MEMORY_UTILS.yaml → archive/MEMORY_UTILS.yaml} +1 -1
- package/.agent/core/{REFLECTION_ENGINE.yaml → archive/REFLECTION_ENGINE.yaml} +1 -1
- package/.agent/core/{ROUTER.yaml → archive/ROUTER.yaml} +5 -5
- package/.agent/core/{SCORING_FORMULA.yaml → archive/SCORING_FORMULA.yaml} +2 -2
- package/.agent/core/{SEMANTIC_ENGINE.yaml → archive/SEMANTIC_ENGINE.yaml} +2 -2
- package/.agent/core/{SKILLS_FLOW.yaml → archive/SKILLS_FLOW.yaml} +2 -2
- package/.agent/core/{STATE_MACHINE.yaml → archive/STATE_MACHINE.yaml} +1 -1
- package/.agent/core/{SUMMARIZATION_ENGINE.yaml → archive/SUMMARIZATION_ENGINE.yaml} +2 -2
- package/.agent/core/{TOKEN_BUDGETS.yaml → archive/TOKEN_BUDGETS.yaml} +2 -2
- package/.agent/core/{TOKEN_LOADING.yaml → archive/TOKEN_LOADING.yaml} +2 -2
- package/.agent/core/{TOKEN_SUMMARY.yaml → archive/TOKEN_SUMMARY.yaml} +2 -2
- package/.agent/core/{CODING_STYLES.yaml → reference/CODING_STYLES.yaml} +1 -1
- package/.agent/core/{LIBRARY_REGISTRY.yaml → reference/LIBRARY_REGISTRY.yaml} +1 -1
- package/.agent/core/{MCP_TOOLS.yaml → reference/MCP_TOOLS.yaml} +2 -2
- package/.agent/core/{PATTERNS.yaml → reference/PATTERNS.yaml} +1 -1
- package/.agent/core/{SKILL_SCHEMA.yaml → reference/SKILL_SCHEMA.yaml} +2 -2
- package/.agent/core/{TEMPLATES.yaml → reference/TEMPLATES.yaml} +1 -1
- package/.agent/i18n/en.yaml +6 -6
- package/.agent/i18n/vi.yaml +6 -6
- package/.agent/ide/README.md +1 -1
- package/.agent/ide/amazonq.json +3 -3
- package/.agent/ide/amp.json +4 -3
- package/.agent/ide/antigravity.json +4 -3
- package/.agent/ide/augment.json +4 -4
- package/.agent/ide/claude.json +4 -3
- package/.agent/ide/cline.json +4 -3
- package/.agent/ide/codex.json +6 -1
- package/.agent/ide/cody.json +4 -3
- package/.agent/ide/continue.json +4 -3
- package/.agent/ide/cursor.json +4 -3
- package/.agent/ide/gemini.json +4 -3
- package/.agent/ide/jetbrains.json +4 -3
- package/.agent/ide/kiro.json +4 -3
- package/.agent/ide/opencode.json +4 -3
- package/.agent/ide/roo.json +4 -3
- package/.agent/ide/tabnine.json +4 -3
- package/.agent/ide/trae.json +4 -3
- package/.agent/ide/vscode.json +4 -3
- package/.agent/ide/windsurf.json +4 -3
- package/.agent/ide/zed.json +4 -3
- package/.agent/manifest.yaml +142 -34
- package/.agent/memory/core_memory/persona.json +2 -2
- package/.agent/memory/core_memory/project.json +1 -1
- package/.agent/memory/core_memory/rules.json +1 -1
- package/.agent/memory/core_memory/user.json +1 -1
- package/.agent/memory/graph/knowledge_graph.json +1 -1
- package/.agent/memory/patterns/errors.json +1 -1
- package/.agent/memory/patterns/successes.json +1 -1
- package/.agent/memory/state.json +3 -3
- package/.agent/personas/README.md +1 -1
- package/.agent/personas/architect.md +1 -1
- package/.agent/personas/auditor.md +1 -1
- package/.agent/personas/debugger.md +1 -1
- package/.agent/personas/developer.md +1 -1
- package/.agent/personas/devops.md +1 -1
- package/.agent/personas/documenter.md +1 -1
- package/.agent/personas/orchestrator.md +1 -1
- package/.agent/personas/persona.schema.yaml +1 -1
- package/.agent/personas/planner.md +1 -1
- package/.agent/personas/researcher.md +1 -1
- package/.agent/personas/security.md +1 -1
- package/.agent/personas/tester.md +1 -1
- package/.agent/private/README.md +74 -0
- package/.agent/private/_index.yaml +23 -0
- package/.agent/private/_template/META.yaml +38 -0
- package/.agent/private/_template/SKILL.md +43 -0
- package/.agent/private/_template/data/.gitkeep +0 -0
- package/.agent/private/autodomyh-api/META.yaml +48 -0
- package/.agent/private/autodomyh-api/SKILL.md +141 -0
- package/.agent/private/autodomyh-api/data/conventions.yaml +107 -0
- package/.agent/rules/README.md +24 -18
- package/.agent/rules/SACRED_RULES.xml +42 -36
- package/.agent/rules/{constitutional → archive/constitutional}/tier-0-core.yaml +6 -6
- package/.agent/rules/{constitutional → archive/constitutional}/tier-1-safety.yaml +6 -6
- package/.agent/rules/{constitutional → archive/constitutional}/tier-2-execution.yaml +7 -7
- package/.agent/rules/{modules → archive}/context-management.yaml +1 -1
- package/.agent/rules/{duplication-prevention.md → archive/duplication-prevention.md} +1 -1
- package/.agent/rules/{modules → archive}/evidence.yaml +1 -1
- package/.agent/rules/{project-detection.md → archive/project-detection.md} +1 -1
- package/.agent/rules/{modules → archive}/reflection.yaml +2 -2
- package/.agent/rules/{modules → archive}/versioning.yaml +3 -3
- package/.agent/rules/data/build-systems.yaml +2 -2
- package/.agent/rules/modules/agent-delegation.yaml +136 -0
- package/.agent/rules/modules/edit-verification.yaml +1 -1
- package/.agent/rules/modules/git-workflow.yaml +1 -1
- package/.agent/rules/modules/language.yaml +1 -1
- package/.agent/rules/modules/online-research.yaml +1 -1
- package/.agent/rules/modules/performance-optimization.yaml +141 -0
- package/.agent/rules/modules/quality.yaml +1 -1
- package/.agent/rules/modules/stop-conditions.yaml +1 -1
- package/.agent/rules/modules/terminal-safety.yaml +45 -1
- package/.agent/rules/modules/yagni.yaml +1 -1
- package/.agent/rules/validation-framework.md +1 -1
- package/.agent/skills/DEVELOPMENT.yaml +17 -6
- package/.agent/skills/README.md +19 -16
- package/.agent/skills/_categories.yaml +60 -8
- package/.agent/skills/_router.yaml +61 -19
- package/.agent/skills/ai-ml/ai-agents/META.yaml +127 -0
- package/.agent/skills/ai-ml/ai-agents/SKILL.md +139 -0
- package/.agent/skills/ai-ml/ai-agents/data/agent-rules.yaml +120 -0
- package/.agent/skills/ai-ml/ai-agents/data/llm-integration.yaml +129 -0
- package/.agent/skills/ai-ml/ai-agents/data/memory-patterns.yaml +123 -0
- package/.agent/skills/ai-ml/ai-agents/data/orchestration-patterns.yaml +101 -0
- package/.agent/skills/ai-ml/gemini-live/META.yaml +55 -0
- package/.agent/skills/ai-ml/gemini-live/SKILL.md +155 -0
- package/.agent/skills/ai-ml/gemini-live/data/code-execution.yaml +131 -0
- package/.agent/skills/ai-ml/gemini-live/data/context-caching.yaml +96 -0
- package/.agent/skills/ai-ml/gemini-live/data/grounding.yaml +97 -0
- package/.agent/skills/ai-ml/gemini-live/data/live-api.yaml +103 -0
- package/.agent/skills/ai-ml/gemini-media-gen/META.yaml +56 -0
- package/.agent/skills/ai-ml/gemini-media-gen/SKILL.md +128 -0
- package/.agent/skills/ai-ml/gemini-media-gen/data/files-api.yaml +96 -0
- package/.agent/skills/ai-ml/gemini-media-gen/data/image-models.yaml +112 -0
- package/.agent/skills/ai-ml/gemini-media-gen/data/image-prompts.yaml +131 -0
- package/.agent/skills/ai-ml/gemini-media-gen/data/video-generation.yaml +131 -0
- package/.agent/skills/ai-ml/gemini-tts/META.yaml +49 -0
- package/.agent/skills/ai-ml/gemini-tts/SKILL.md +124 -0
- package/.agent/skills/ai-ml/gemini-tts/data/markup-tags.yaml +95 -0
- package/.agent/skills/ai-ml/gemini-tts/data/models.yaml +124 -0
- package/.agent/skills/ai-ml/gemini-tts/data/prompting-patterns.yaml +81 -0
- package/.agent/skills/ai-ml/prompt-engineering/META.yaml +77 -0
- package/.agent/skills/ai-ml/prompt-engineering/SKILL.md +217 -0
- package/.agent/skills/ai-ml/prompt-engineering/data/gemini3-patterns.yaml +170 -0
- package/.agent/skills/ai-ml/prompt-engineering/data/output-patterns.yaml +73 -0
- package/.agent/skills/ai-ml/prompt-engineering/data/provider-patterns.yaml +82 -0
- package/.agent/skills/ai-ml/prompt-engineering/data/reasoning-patterns.yaml +86 -0
- package/.agent/skills/ai-ml/prompt-engineering/data/safety-patterns.yaml +71 -0
- package/.agent/skills/ai-ml/prompt-engineering/data/tool-patterns.yaml +173 -0
- package/.agent/skills/ai-ml/rag-patterns/META.yaml +57 -0
- package/.agent/skills/ai-ml/rag-patterns/SKILL.md +92 -0
- package/.agent/skills/ai-ml/rag-patterns/data/chunking-strategies.yaml +71 -0
- package/.agent/skills/ai-ml/rag-patterns/data/embedding-models.yaml +76 -0
- package/.agent/skills/ai-ml/rag-patterns/data/evaluation.yaml +92 -0
- package/.agent/skills/ai-ml/rag-patterns/data/retrieval-patterns.yaml +101 -0
- package/.agent/skills/ai-ml/rag-patterns/data/vector-databases.yaml +103 -0
- package/.agent/skills/ai-ml/vector-search/META.yaml +63 -0
- package/.agent/skills/ai-ml/vector-search/SKILL.md +110 -0
- package/.agent/skills/ai-ml/vector-search/data/embedding-models.yaml +117 -0
- package/.agent/skills/ai-ml/vector-search/data/search-patterns.yaml +118 -0
- package/.agent/skills/ai-ml/vector-search/data/vector-dbs.yaml +155 -0
- package/.agent/skills/core/api-design/META.yaml +1 -5
- package/.agent/skills/core/api-design/SKILL.md +20 -26
- package/.agent/skills/core/api-design/data/api-versioning.yaml +211 -211
- package/.agent/skills/core/api-design/data/error-responses.yaml +129 -129
- package/.agent/skills/core/api-design/data/graphql-patterns.yaml +159 -159
- package/.agent/skills/core/api-design/data/grpc-patterns.yaml +159 -159
- package/.agent/skills/core/api-design/data/http-status-codes.yaml +170 -170
- package/.agent/skills/core/api-design/data/modern-api-patterns.yaml +160 -0
- package/.agent/skills/core/api-design/data/pagination.yaml +115 -115
- package/.agent/skills/core/api-design/data/rate-limiting.yaml +129 -129
- package/.agent/skills/core/api-design/data/rest-patterns.yaml +189 -189
- package/.agent/skills/core/api-design/data/test-apis.yaml +211 -211
- package/.agent/skills/core/authentication/META.yaml +1 -5
- package/.agent/skills/core/authentication/SKILL.md +36 -43
- package/.agent/skills/core/authentication/data/anti-patterns.yaml +129 -129
- package/.agent/skills/core/authentication/data/core-patterns.yaml +250 -250
- package/.agent/skills/core/authentication/data/jwt-patterns.yaml +249 -249
- package/.agent/skills/core/authentication/data/language-csharp.yaml +209 -209
- package/.agent/skills/core/authentication/data/language-go.yaml +209 -209
- package/.agent/skills/core/authentication/data/language-java.yaml +209 -209
- package/.agent/skills/core/authentication/data/language-mobile.yaml +209 -209
- package/.agent/skills/core/authentication/data/language-python.yaml +209 -209
- package/.agent/skills/core/authentication/data/language-rust.yaml +209 -209
- package/.agent/skills/core/authentication/data/language-typescript.yaml +209 -209
- package/.agent/skills/core/authentication/data/mfa-patterns.yaml +169 -169
- package/.agent/skills/core/authentication/data/oauth-patterns.yaml +249 -249
- package/.agent/skills/core/authentication/data/oauth.yaml +243 -243
- package/.agent/skills/core/authentication/data/passkey-patterns.yaml +149 -0
- package/.agent/skills/core/authentication/data/passkeys-webauthn.yaml +209 -209
- package/.agent/skills/core/authentication/data/passkeys.yaml +203 -203
- package/.agent/skills/core/authentication/data/password-patterns.yaml +169 -169
- package/.agent/skills/core/authentication/data/password.yaml +163 -163
- package/.agent/skills/core/authentication/data/session-patterns.yaml +209 -209
- package/.agent/skills/core/error-handling/META.yaml +1 -5
- package/.agent/skills/core/error-handling/SKILL.md +21 -25
- package/.agent/skills/core/error-handling/data/anti-patterns.yaml +99 -99
- package/.agent/skills/core/error-handling/data/api-error-patterns.yaml +2 -2
- package/.agent/skills/core/error-handling/data/core-patterns.yaml +2 -2
- package/.agent/skills/core/error-handling/data/error-codes.yaml +159 -159
- package/.agent/skills/core/error-handling/data/error-messages.yaml +2 -2
- package/.agent/skills/core/error-handling/data/language-c-cpp.yaml +220 -220
- package/.agent/skills/core/error-handling/data/language-go-rust.yaml +2 -2
- package/.agent/skills/core/error-handling/data/language-python-java.yaml +220 -220
- package/.agent/skills/core/error-handling/data/language-swift-kotlin.yaml +220 -220
- package/.agent/skills/core/error-handling/data/language-typescript-php-ruby.yaml +220 -220
- package/.agent/skills/core/error-handling/data/resilience-patterns.yaml +2 -2
- package/.agent/skills/core/error-handling/data/ui-error-patterns.yaml +129 -129
- package/.agent/skills/core/logging/META.yaml +1 -5
- package/.agent/skills/core/logging/SKILL.md +28 -42
- package/.agent/skills/core/logging/data/aggregation-patterns.yaml +185 -185
- package/.agent/skills/core/logging/data/anti-patterns.yaml +115 -115
- package/.agent/skills/core/logging/data/core-patterns.yaml +220 -220
- package/.agent/skills/core/logging/data/language-csharp.yaml +185 -185
- package/.agent/skills/core/logging/data/language-go.yaml +185 -185
- package/.agent/skills/core/logging/data/language-java.yaml +185 -185
- package/.agent/skills/core/logging/data/language-kotlin.yaml +150 -150
- package/.agent/skills/core/logging/data/language-others.yaml +178 -178
- package/.agent/skills/core/logging/data/language-python.yaml +185 -185
- package/.agent/skills/core/logging/data/language-rust.yaml +185 -185
- package/.agent/skills/core/logging/data/language-swift.yaml +150 -150
- package/.agent/skills/core/logging/data/language-typescript.yaml +185 -185
- package/.agent/skills/core/logging/data/otel-logging.yaml +150 -150
- package/.agent/skills/core/observability/META.yaml +1 -5
- package/.agent/skills/core/observability/SKILL.md +29 -38
- package/.agent/skills/core/observability/data/alerting-patterns.yaml +159 -159
- package/.agent/skills/core/observability/data/anti-patterns.yaml +99 -99
- package/.agent/skills/core/observability/data/core-patterns.yaml +189 -189
- package/.agent/skills/core/observability/data/language-cpp.yaml +159 -159
- package/.agent/skills/core/observability/data/language-csharp.yaml +159 -159
- package/.agent/skills/core/observability/data/language-go.yaml +159 -159
- package/.agent/skills/core/observability/data/language-java.yaml +159 -159
- package/.agent/skills/core/observability/data/language-others.yaml +249 -249
- package/.agent/skills/core/observability/data/language-python.yaml +159 -159
- package/.agent/skills/core/observability/data/language-rust.yaml +159 -159
- package/.agent/skills/core/observability/data/language-typescript.yaml +159 -159
- package/.agent/skills/core/observability/data/metrics-patterns.yaml +129 -129
- package/.agent/skills/core/observability/data/metrics-prometheus.yaml +159 -159
- package/.agent/skills/core/observability/data/otel-core.yaml +189 -189
- package/.agent/skills/core/observability/data/profiling-patterns.yaml +129 -129
- package/.agent/skills/core/observability/data/tracing-patterns.yaml +159 -159
- package/.agent/skills/core/observability/data/tracing-tools.yaml +129 -129
- package/.agent/skills/core/security/META.yaml +1 -5
- package/.agent/skills/core/security/SKILL.md +25 -25
- package/.agent/skills/core/security/data/ai-ml-security.yaml +255 -255
- package/.agent/skills/core/security/data/api-security.yaml +224 -224
- package/.agent/skills/core/security/data/auth-patterns.yaml +189 -189
- package/.agent/skills/core/security/data/binary-exploitation.yaml +333 -333
- package/.agent/skills/core/security/data/cloud-security.yaml +263 -263
- package/.agent/skills/core/security/data/cwe-top25.yaml +409 -409
- package/.agent/skills/core/security/data/language-specific/c-security.yaml +289 -289
- package/.agent/skills/core/security/data/language-specific/cpp-security.yaml +289 -289
- package/.agent/skills/core/security/data/language-specific/csharp-security.yaml +213 -213
- package/.agent/skills/core/security/data/language-specific/go-security.yaml +213 -213
- package/.agent/skills/core/security/data/language-specific/java-security.yaml +289 -289
- package/.agent/skills/core/security/data/language-specific/kotlin-security.yaml +192 -192
- package/.agent/skills/core/security/data/language-specific/php-security.yaml +213 -213
- package/.agent/skills/core/security/data/language-specific/python-security.yaml +289 -289
- package/.agent/skills/core/security/data/language-specific/ruby-security.yaml +192 -192
- package/.agent/skills/core/security/data/language-specific/rust-security.yaml +234 -234
- package/.agent/skills/core/security/data/language-specific/solidity-security.yaml +363 -363
- package/.agent/skills/core/security/data/language-specific/swift-security.yaml +192 -192
- package/.agent/skills/core/security/data/language-specific/typescript-security.yaml +289 -289
- package/.agent/skills/core/security/data/mobile-security.yaml +363 -363
- package/.agent/skills/core/security/data/network-security.yaml +291 -291
- package/.agent/skills/core/security/data/owasp-llm-top10.yaml +122 -0
- package/.agent/skills/core/security/data/owasp-top10.yaml +165 -165
- package/.agent/skills/core/security/data/reverse-engineering.yaml +491 -491
- package/.agent/skills/core/security/data/supply-chain.yaml +213 -213
- package/.agent/skills/cross-cutting/_index.yaml +4 -2
- package/.agent/skills/cross-cutting/accessibility/META.yaml +45 -0
- package/.agent/skills/cross-cutting/accessibility/SKILL.md +121 -0
- package/.agent/skills/cross-cutting/accessibility/data/aria-patterns.yaml +88 -0
- package/.agent/skills/cross-cutting/accessibility/data/testing-tools.yaml +60 -0
- package/.agent/skills/cross-cutting/accessibility/data/wcag-guidelines.yaml +98 -0
- package/.agent/skills/cross-cutting/audit-pro/META.yaml +2 -6
- package/.agent/skills/cross-cutting/audit-pro/SKILL.md +61 -0
- package/.agent/skills/cross-cutting/bun/META.yaml +2 -8
- package/.agent/skills/cross-cutting/bun/SKILL.md +8 -12
- package/.agent/skills/cross-cutting/coding-rules/META.yaml +4 -11
- package/.agent/skills/cross-cutting/coding-rules/SKILL.md +38 -46
- package/.agent/skills/cross-cutting/coding-rules/data/adr-patterns.yaml +102 -0
- package/.agent/skills/cross-cutting/coding-rules/data/architecture-patterns.yaml +289 -90
- package/.agent/skills/cross-cutting/coding-rules/data/build-systems.yaml +340 -340
- package/.agent/skills/cross-cutting/coding-rules/data/coding-rules.yaml +641 -641
- package/.agent/skills/cross-cutting/coding-rules/data/concurrency-patterns.yaml +102 -102
- package/.agent/skills/cross-cutting/coding-rules/data/design-patterns.yaml +254 -254
- package/.agent/skills/cross-cutting/coding-rules/data/framework-directories.yaml +446 -0
- package/.agent/skills/cross-cutting/coding-rules/data/framework-signatures.yaml +338 -338
- package/.agent/skills/cross-cutting/coding-rules/data/memory-management.yaml +102 -102
- package/.agent/skills/cross-cutting/coding-rules/data/naming-conventions.yaml +314 -314
- package/.agent/skills/cross-cutting/coding-rules/data/performance-benchmarks.yaml +158 -158
- package/.agent/skills/cross-cutting/coding-rules/data/solid-principles.yaml +74 -74
- package/.agent/skills/cross-cutting/coding-rules/data/test-frameworks.yaml +177 -177
- package/.agent/skills/cross-cutting/database/META.yaml +2 -2
- package/.agent/skills/cross-cutting/database/SKILL.md +10 -19
- package/.agent/skills/cross-cutting/deno/META.yaml +2 -8
- package/.agent/skills/cross-cutting/deno/SKILL.md +8 -12
- package/.agent/skills/cross-cutting/domyh-design/ADVANCED.md +247 -0
- package/.agent/skills/cross-cutting/{ui-ux-pro-max → domyh-design}/META.yaml +44 -13
- package/.agent/skills/cross-cutting/domyh-design/SKILL.md +171 -0
- package/.agent/skills/cross-cutting/domyh-design/data/animation-ui-kits.yaml +198 -0
- package/.agent/skills/cross-cutting/domyh-design/data/charts.yaml +331 -0
- package/.agent/skills/cross-cutting/domyh-design/data/colors.yaml +1226 -0
- package/.agent/skills/cross-cutting/domyh-design/data/component-decision.yaml +287 -0
- package/.agent/skills/cross-cutting/domyh-design/data/component-effects.yaml +673 -0
- package/.agent/skills/cross-cutting/domyh-design/data/component-mapping.yaml +318 -0
- package/.agent/skills/cross-cutting/domyh-design/data/design-system-prompts.yaml +174 -0
- package/.agent/skills/cross-cutting/domyh-design/data/design-tokens.yaml +525 -0
- package/.agent/skills/cross-cutting/domyh-design/data/desktop-animation.yaml +680 -0
- package/.agent/skills/cross-cutting/domyh-design/data/desktop-architecture.yaml +140 -0
- package/.agent/skills/cross-cutting/{ui-ux-pro-max → domyh-design}/data/desktop-colors.yaml +4 -4
- package/.agent/skills/cross-cutting/domyh-design/data/directory-structure.yaml +80 -0
- package/.agent/skills/cross-cutting/domyh-design/data/icons.yaml +918 -0
- package/.agent/skills/cross-cutting/domyh-design/data/image-gen-prompts.yaml +678 -0
- package/.agent/skills/cross-cutting/domyh-design/data/image-gen-workflows.yaml +202 -0
- package/.agent/skills/cross-cutting/domyh-design/data/implementation-strategy.yaml +107 -0
- package/.agent/skills/cross-cutting/domyh-design/data/landing.yaml +373 -0
- package/.agent/skills/cross-cutting/domyh-design/data/micro-interactions.yaml +528 -0
- package/.agent/skills/cross-cutting/domyh-design/data/platform-frameworks.yaml +195 -0
- package/.agent/skills/cross-cutting/domyh-design/data/platform-guidelines.yaml +177 -0
- package/.agent/skills/cross-cutting/domyh-design/data/products.yaml +1339 -0
- package/.agent/skills/cross-cutting/domyh-design/data/prompts.yaml +207 -0
- package/.agent/skills/cross-cutting/domyh-design/data/react-performance.yaml +504 -0
- package/.agent/skills/cross-cutting/domyh-design/data/scroll-animation-patterns.yaml +398 -0
- package/.agent/skills/cross-cutting/domyh-design/data/stacks/desktop.yaml +228 -0
- package/.agent/skills/cross-cutting/domyh-design/data/stacks/flutter.yaml +508 -0
- package/.agent/skills/cross-cutting/domyh-design/data/stacks/html-tailwind.yaml +543 -0
- package/.agent/skills/cross-cutting/domyh-design/data/stacks/nextjs.yaml +515 -0
- package/.agent/skills/cross-cutting/domyh-design/data/stacks/nuxt-ui.yaml +519 -0
- package/.agent/skills/cross-cutting/domyh-design/data/stacks/nuxtjs.yaml +599 -0
- package/.agent/skills/cross-cutting/domyh-design/data/stacks/react-native.yaml +496 -0
- package/.agent/skills/cross-cutting/domyh-design/data/stacks/react.yaml +526 -0
- package/.agent/skills/cross-cutting/domyh-design/data/stacks/shadcn.yaml +616 -0
- package/.agent/skills/cross-cutting/domyh-design/data/stacks/svelte.yaml +520 -0
- package/.agent/skills/cross-cutting/domyh-design/data/stacks/swiftui.yaml +486 -0
- package/.agent/skills/cross-cutting/domyh-design/data/stacks/vue.yaml +485 -0
- package/.agent/skills/cross-cutting/domyh-design/data/styles.yaml +1473 -0
- package/.agent/skills/cross-cutting/domyh-design/data/tailwind-animation-plugins.yaml +462 -0
- package/.agent/skills/cross-cutting/domyh-design/data/typography.yaml +647 -0
- package/.agent/skills/cross-cutting/domyh-design/data/ui-reasoning.yaml +1019 -0
- package/.agent/skills/cross-cutting/domyh-design/data/ux-guidelines.yaml +1009 -0
- package/.agent/skills/cross-cutting/domyh-design/data/web-animation-libraries.yaml +541 -0
- package/.agent/skills/cross-cutting/domyh-design/data/web-interface.yaml +347 -0
- package/.agent/skills/cross-cutting/domyh-design/data/webview-animation-optimization.yaml +685 -0
- package/.agent/skills/cross-cutting/electron/SKILL.md +10 -14
- package/.agent/skills/cross-cutting/event-driven/META.yaml +108 -0
- package/.agent/skills/cross-cutting/event-driven/SKILL.md +123 -0
- package/.agent/skills/cross-cutting/event-driven/data/broker-comparison.yaml +123 -0
- package/.agent/skills/cross-cutting/event-driven/data/eda-patterns.yaml +120 -0
- package/.agent/skills/cross-cutting/event-driven/data/production-patterns.yaml +120 -0
- package/.agent/skills/cross-cutting/microservices/META.yaml +90 -0
- package/.agent/skills/cross-cutting/microservices/SKILL.md +120 -0
- package/.agent/skills/cross-cutting/microservices/data/communication.yaml +163 -0
- package/.agent/skills/cross-cutting/microservices/data/cqrs-patterns.yaml +199 -0
- package/.agent/skills/cross-cutting/microservices/data/deployment.yaml +153 -0
- package/.agent/skills/cross-cutting/microservices/data/event-sourcing.yaml +231 -0
- package/.agent/skills/cross-cutting/microservices/data/observability.yaml +152 -0
- package/.agent/skills/cross-cutting/microservices/data/resilience.yaml +189 -0
- package/.agent/skills/cross-cutting/microservices/data/saga-patterns.yaml +161 -0
- package/.agent/skills/cross-cutting/microservices/data/service-mesh.yaml +179 -0
- package/.agent/skills/cross-cutting/monorepo/META.yaml +54 -0
- package/.agent/skills/cross-cutting/monorepo/SKILL.md +108 -0
- package/.agent/skills/cross-cutting/monorepo/data/ci-cd-strategies.yaml +74 -0
- package/.agent/skills/cross-cutting/monorepo/data/nx-patterns.yaml +74 -0
- package/.agent/skills/cross-cutting/monorepo/data/turborepo-patterns.yaml +84 -0
- package/.agent/skills/cross-cutting/monorepo/data/versioning.yaml +83 -0
- package/.agent/skills/cross-cutting/monorepo/data/workspace-patterns.yaml +85 -0
- package/.agent/skills/cross-cutting/playwright/ADVANCED.md +289 -0
- package/.agent/skills/cross-cutting/playwright/META.yaml +90 -0
- package/.agent/skills/cross-cutting/playwright/SKILL.md +210 -0
- package/.agent/skills/cross-cutting/playwright/data/ai-agents.yaml +137 -0
- package/.agent/skills/cross-cutting/playwright/data/config-templates.yaml +141 -0
- package/.agent/skills/cross-cutting/playwright/data/interaction-checklist.yaml +398 -0
- package/.agent/skills/cross-cutting/playwright/data/locator-patterns.yaml +96 -0
- package/.agent/skills/cross-cutting/playwright/data/mcp-tools.yaml +153 -0
- package/.agent/skills/cross-cutting/playwright/data/open-source-tools.yaml +95 -0
- package/.agent/skills/cross-cutting/real-time/META.yaml +72 -0
- package/.agent/skills/cross-cutting/real-time/SKILL.md +128 -0
- package/.agent/skills/cross-cutting/real-time/data/socketio-patterns.yaml +165 -0
- package/.agent/skills/cross-cutting/real-time/data/sse-patterns.yaml +181 -0
- package/.agent/skills/cross-cutting/real-time/data/websocket-patterns.yaml +176 -0
- package/.agent/skills/cross-cutting/seo/META.yaml +47 -0
- package/.agent/skills/cross-cutting/seo/SKILL.md +114 -0
- package/.agent/skills/cross-cutting/seo/data/core-web-vitals.yaml +93 -0
- package/.agent/skills/cross-cutting/seo/data/structured-data.yaml +82 -0
- package/.agent/skills/cross-cutting/seo/data/technical-seo.yaml +75 -0
- package/.agent/skills/cross-cutting/sql/META.yaml +2 -8
- package/.agent/skills/cross-cutting/sql/SKILL.md +8 -12
- package/.agent/skills/cross-cutting/tailwind/META.yaml +3 -20
- package/.agent/skills/cross-cutting/tailwind/SKILL.md +13 -11
- package/.agent/skills/cross-cutting/tauri/META.yaml +75 -0
- package/.agent/skills/cross-cutting/tauri/SKILL.md +127 -0
- package/.agent/skills/cross-cutting/tauri/data/build.yaml +141 -0
- package/.agent/skills/cross-cutting/tauri/data/plugins.yaml +157 -0
- package/.agent/skills/cross-cutting/tauri/data/security.yaml +134 -0
- package/.agent/skills/cross-cutting/tdd-workflow/META.yaml +58 -0
- package/.agent/skills/cross-cutting/tdd-workflow/SKILL.md +128 -0
- package/.agent/skills/cross-cutting/tdd-workflow/data/anti-patterns.yaml +70 -0
- package/.agent/skills/cross-cutting/tdd-workflow/data/bdd-atdd-patterns.yaml +77 -0
- package/.agent/skills/cross-cutting/tdd-workflow/data/core-tdd-cycle.yaml +104 -0
- package/.agent/skills/cross-cutting/tdd-workflow/data/coverage-strategies.yaml +105 -0
- package/.agent/skills/cross-cutting/tdd-workflow/data/language-patterns.yaml +115 -0
- package/.agent/skills/cross-cutting/tdd-workflow/data/test-doubles.yaml +93 -0
- package/.agent/skills/cross-cutting/testing/META.yaml +1 -5
- package/.agent/skills/cross-cutting/testing/SKILL.md +13 -26
- package/.agent/skills/cross-cutting/testing/data/e2e-patterns.yaml +136 -0
- package/.agent/skills/cross-cutting/testing/data/frameworks.yaml +3 -3
- package/.agent/skills/cross-cutting/testing/data/patterns.yaml +149 -147
- package/.agent/skills/cross-cutting/wasm/META.yaml +47 -0
- package/.agent/skills/cross-cutting/wasm/SKILL.md +88 -0
- package/.agent/skills/cross-cutting/wasm/data/browser-patterns.yaml +106 -0
- package/.agent/skills/cross-cutting/wasm/data/component-model.yaml +85 -0
- package/.agent/skills/cross-cutting/wasm/data/server-patterns.yaml +89 -0
- package/.agent/skills/cross-cutting/web-perf/META.yaml +3 -9
- package/.agent/skills/cross-cutting/web-perf/SKILL.md +9 -18
- package/.agent/skills/devops/aws/META.yaml +48 -63
- package/.agent/skills/devops/aws/SKILL.md +39 -697
- package/.agent/skills/devops/azure/META.yaml +44 -0
- package/.agent/skills/devops/azure/SKILL.md +43 -0
- package/.agent/skills/devops/azure/data/cli.yaml +69 -0
- package/.agent/skills/devops/azure/data/compute.yaml +83 -0
- package/.agent/skills/devops/azure/data/data-services.yaml +126 -0
- package/.agent/skills/devops/ci-cd/META.yaml +47 -14
- package/.agent/skills/devops/ci-cd/SKILL.md +37 -807
- package/.agent/skills/devops/docker/META.yaml +53 -14
- package/.agent/skills/devops/docker/SKILL.md +35 -639
- package/.agent/skills/devops/gcp/META.yaml +43 -0
- package/.agent/skills/devops/gcp/SKILL.md +43 -0
- package/.agent/skills/devops/gcp/data/cli.yaml +39 -0
- package/.agent/skills/devops/gcp/data/compute.yaml +92 -0
- package/.agent/skills/devops/gcp/data/data-services.yaml +97 -0
- package/.agent/skills/devops/kubernetes/META.yaml +56 -7
- package/.agent/skills/devops/kubernetes/SKILL.md +38 -607
- package/.agent/skills/devops/terraform/META.yaml +47 -0
- package/.agent/skills/devops/terraform/SKILL.md +73 -0
- package/.agent/skills/devops/terraform/data/ci-cd.yaml +89 -0
- package/.agent/skills/devops/terraform/data/hcl-patterns.yaml +131 -0
- package/.agent/skills/devops/terraform/data/providers.yaml +96 -0
- package/.agent/skills/frameworks/angular/META.yaml +20 -6
- package/.agent/skills/frameworks/angular/SKILL.md +1 -1
- package/.agent/skills/frameworks/flutter/META.yaml +20 -6
- package/.agent/skills/frameworks/flutter/SKILL.md +1 -1
- package/.agent/skills/frameworks/nextjs/ADVANCED.md +2 -2
- package/.agent/skills/frameworks/nextjs/META.yaml +22 -8
- package/.agent/skills/frameworks/nextjs/SKILL.md +4 -4
- package/.agent/skills/frameworks/nextjs/data/server.yaml +4 -4
- package/.agent/skills/frameworks/nuxt/META.yaml +21 -7
- package/.agent/skills/frameworks/nuxt/SKILL.md +2 -2
- package/.agent/skills/frameworks/nuxt/data/core.yaml +14 -2
- package/.agent/skills/frameworks/nuxt/data/server.yaml +14 -2
- package/.agent/skills/frameworks/react/META.yaml +20 -7
- package/.agent/skills/frameworks/react/SKILL.md +7 -11
- package/.agent/skills/frameworks/react/data/core.yaml +14 -2
- package/.agent/skills/frameworks/react/data/server.yaml +16 -4
- package/.agent/skills/frameworks/react-native/META.yaml +19 -6
- package/.agent/skills/frameworks/react-native/SKILL.md +1 -1
- package/.agent/skills/frameworks/svelte/META.yaml +19 -6
- package/.agent/skills/frameworks/svelte/SKILL.md +1 -1
- package/.agent/skills/frameworks/vue/META.yaml +20 -8
- package/.agent/skills/frameworks/vue/SKILL.md +7 -7
- package/.agent/skills/frameworks/vue/data/advanced.yaml +19 -7
- package/.agent/skills/frameworks/vue/data/core.yaml +13 -1
- package/.agent/skills/index.json +67 -14
- package/.agent/skills/languages/asm/META.yaml +2 -8
- package/.agent/skills/languages/asm/SKILL.md +1 -1
- package/.agent/skills/languages/c/META.yaml +2 -8
- package/.agent/skills/languages/c/SKILL.md +1 -1
- package/.agent/skills/languages/clojure/META.yaml +2 -2
- package/.agent/skills/languages/clojure/SKILL.md +1 -1
- package/.agent/skills/languages/cpp/META.yaml +2 -8
- package/.agent/skills/languages/cpp/SKILL.md +1 -1
- package/.agent/skills/languages/crystal/META.yaml +2 -8
- package/.agent/skills/languages/crystal/SKILL.md +1 -1
- package/.agent/skills/languages/csharp/META.yaml +2 -2
- package/.agent/skills/languages/csharp/SKILL.md +1 -1
- package/.agent/skills/languages/elixir/META.yaml +2 -2
- package/.agent/skills/languages/elixir/SKILL.md +1 -1
- package/.agent/skills/languages/fsharp/META.yaml +2 -2
- package/.agent/skills/languages/fsharp/SKILL.md +1 -1
- package/.agent/skills/languages/go/META.yaml +2 -8
- package/.agent/skills/languages/go/SKILL.md +1 -1
- package/.agent/skills/languages/haskell/META.yaml +2 -2
- package/.agent/skills/languages/haskell/SKILL.md +1 -1
- package/.agent/skills/languages/java/META.yaml +2 -8
- package/.agent/skills/languages/java/SKILL.md +1 -1
- package/.agent/skills/languages/javascript/META.yaml +2 -8
- package/.agent/skills/languages/javascript/SKILL.md +1 -1
- package/.agent/skills/languages/julia/META.yaml +2 -2
- package/.agent/skills/languages/julia/SKILL.md +1 -1
- package/.agent/skills/languages/kotlin/META.yaml +2 -2
- package/.agent/skills/languages/kotlin/SKILL.md +1 -1
- package/.agent/skills/languages/lua/META.yaml +2 -8
- package/.agent/skills/languages/lua/SKILL.md +3 -3
- package/.agent/skills/languages/nim/META.yaml +2 -8
- package/.agent/skills/languages/nim/SKILL.md +1 -1
- package/.agent/skills/languages/ocaml/META.yaml +2 -2
- package/.agent/skills/languages/ocaml/SKILL.md +1 -1
- package/.agent/skills/languages/perl/META.yaml +2 -2
- package/.agent/skills/languages/perl/SKILL.md +1 -1
- package/.agent/skills/languages/php/META.yaml +2 -2
- package/.agent/skills/languages/php/SKILL.md +1 -1
- package/.agent/skills/languages/python/META.yaml +2 -8
- package/.agent/skills/languages/python/SKILL.md +1 -1
- package/.agent/skills/languages/r/META.yaml +2 -2
- package/.agent/skills/languages/r/SKILL.md +1 -1
- package/.agent/skills/languages/ruby/META.yaml +2 -2
- package/.agent/skills/languages/ruby/SKILL.md +1 -1
- package/.agent/skills/languages/rust/META.yaml +2 -8
- package/.agent/skills/languages/rust/SKILL.md +1 -1
- package/.agent/skills/languages/scala/META.yaml +2 -2
- package/.agent/skills/languages/scala/SKILL.md +1 -1
- package/.agent/skills/languages/solidity/META.yaml +2 -2
- package/.agent/skills/languages/solidity/SKILL.md +1 -1
- package/.agent/skills/languages/swift/META.yaml +2 -2
- package/.agent/skills/languages/swift/SKILL.md +1 -1
- package/.agent/skills/languages/typescript/META.yaml +2 -8
- package/.agent/skills/languages/typescript/SKILL.md +1 -1
- package/.agent/skills/languages/zig/META.yaml +5 -7
- package/.agent/skills/languages/zig/SKILL.md +1 -1
- package/.agent/skills/tooling/api-protocols/META.yaml +102 -0
- package/.agent/skills/tooling/api-protocols/SKILL.md +145 -0
- package/.agent/skills/tooling/api-protocols/data/graphql-patterns.yaml +115 -0
- package/.agent/skills/tooling/api-protocols/data/grpc-patterns.yaml +101 -0
- package/.agent/skills/tooling/api-protocols/data/trpc-patterns.yaml +97 -0
- package/.agent/skills/tooling/browser-agent/ADVANCED.md +242 -0
- package/.agent/skills/tooling/browser-agent/META.yaml +78 -0
- package/.agent/skills/tooling/browser-agent/SKILL.md +164 -0
- package/.agent/skills/tooling/browser-agent/data/element-discovery.yaml +208 -0
- package/.agent/skills/tooling/browser-agent/data/recording-patterns.yaml +74 -0
- package/.agent/skills/tooling/browser-agent/data/reporting-patterns.yaml +97 -0
- package/.agent/skills/tooling/browser-agent/data/subagent-patterns.yaml +158 -0
- package/.agent/skills/tooling/browser-agent/data/verification-flow.yaml +209 -0
- package/.agent/skills/tooling/cli-dev/META.yaml +55 -0
- package/.agent/skills/tooling/cli-dev/SKILL.md +83 -0
- package/.agent/skills/tooling/cli-dev/data/frameworks.yaml +128 -0
- package/.agent/skills/tooling/cli-dev/data/output-formats.yaml +58 -0
- package/.agent/skills/tooling/cli-dev/data/ux-patterns.yaml +97 -0
- package/.agent/skills/tooling/ide-extension/META.yaml +72 -0
- package/.agent/skills/tooling/ide-extension/SKILL.md +108 -0
- package/.agent/skills/tooling/ide-extension/data/jetbrains-patterns.yaml +118 -0
- package/.agent/skills/tooling/ide-extension/data/lsp-patterns.yaml +126 -0
- package/.agent/skills/tooling/ide-extension/data/vscode-patterns.yaml +172 -0
- package/.agent/skills/tooling/mcp/META.yaml +80 -0
- package/.agent/skills/tooling/mcp/SKILL.md +114 -0
- package/.agent/skills/tooling/mcp/data/security.yaml +116 -0
- package/.agent/skills/tooling/mcp/data/tool-design.yaml +124 -0
- package/.agent/skills/tooling/mcp/data/transport-patterns.yaml +95 -0
- package/.agent/templates/README.md +2 -2
- package/.agent/templates/debug-report.md +1 -1
- package/.agent/templates/deploy-plan.md +1 -1
- package/.agent/templates/doc-template.md +1 -1
- package/.agent/templates/index.yaml +2 -2
- package/.agent/templates/migrate-plan.md +1 -1
- package/.agent/templates/phase-template.md +1 -1
- package/.agent/templates/tasks/audit.yaml +1 -1
- package/.agent/templates/tasks/bug_fix.yaml +1 -1
- package/.agent/templates/tasks/code_implementation.yaml +1 -1
- package/.agent/templates/tasks/refactor.yaml +1 -1
- package/.agent/templates/test-report.md +1 -1
- package/.agent/workflows/code.md +22 -1
- package/.agent/workflows/deploy.md +5 -1
- package/.agent/workflows/e2e.md +112 -0
- package/.agent/workflows/fix.md +1 -1
- package/.agent/workflows/prompt.md +325 -0
- package/.agent/workflows/scaffold.md +1 -1
- package/.agent/workflows/tdd.md +108 -0
- package/.agent/workflows/verify.md +116 -0
- package/.agent/workflows/visualize.md +50 -18
- package/README.md +16 -13
- package/configs/aider/root.CONVENTIONS.md +51 -0
- package/configs/amazonq/root.amazonq.md +51 -0
- package/configs/amp/root.AGENTS.md +51 -0
- package/configs/antigravity/root.GEMINI.md +51 -0
- package/configs/augment/root.guidelines.md +51 -0
- package/configs/claude/root.CLAUDE.md +51 -0
- package/configs/cline/root.clinerules.md +51 -0
- package/configs/coderabbit/root.coderabbit.yaml +52 -0
- package/configs/codex/root.AGENTS.md +51 -0
- package/configs/cody/root.commands.json +76 -0
- package/configs/continue/root.continue.md +51 -0
- package/configs/copilot/root.copilot-instructions.md +51 -0
- package/configs/cursor/root.cursorrules +51 -0
- package/configs/gemini/root.GEMINI.md +51 -0
- package/configs/jetbrains/root.guidelines.md +51 -0
- package/configs/opencode/root.opencode.json +24 -0
- package/configs/roo/root.roorules.md +51 -0
- package/configs/tabnine/root.guidelines.md +51 -0
- package/configs/vscode/root.copilot-instructions.md +51 -0
- package/configs/windsurf/root.windsurfrules +51 -0
- package/configs/zed/root.settings.json +15 -0
- package/dist/commands/add.d.ts.map +1 -1
- package/dist/commands/add.js +9 -1
- package/dist/commands/add.js.map +1 -1
- package/dist/commands/config.d.ts.map +1 -1
- package/dist/commands/config.js +24 -8
- package/dist/commands/config.js.map +1 -1
- package/dist/commands/hsa.d.ts.map +1 -1
- package/dist/commands/hsa.js +106 -20
- package/dist/commands/hsa.js.map +1 -1
- package/dist/commands/init.d.ts.map +1 -1
- package/dist/commands/init.js +62 -69
- package/dist/commands/init.js.map +1 -1
- package/dist/commands/install-core.d.ts +2 -1
- package/dist/commands/install-core.d.ts.map +1 -1
- package/dist/commands/install-core.js +43 -16
- package/dist/commands/install-core.js.map +1 -1
- package/dist/commands/install-helpers.d.ts.map +1 -1
- package/dist/commands/install-helpers.js +25 -2
- package/dist/commands/install-helpers.js.map +1 -1
- package/dist/commands/install-hsa.d.ts +2 -5
- package/dist/commands/install-hsa.d.ts.map +1 -1
- package/dist/commands/install-hsa.js +2 -5
- package/dist/commands/install-hsa.js.map +1 -1
- package/dist/commands/install.d.ts +27 -0
- package/dist/commands/install.d.ts.map +1 -1
- package/dist/commands/install.js +68 -20
- package/dist/commands/install.js.map +1 -1
- package/dist/commands/list.d.ts.map +1 -1
- package/dist/commands/list.js +2 -1
- package/dist/commands/list.js.map +1 -1
- package/dist/commands/mcp-registry.d.ts +24 -9
- package/dist/commands/mcp-registry.d.ts.map +1 -1
- package/dist/commands/mcp-registry.js +39 -57
- package/dist/commands/mcp-registry.js.map +1 -1
- package/dist/commands/mcp-writers.d.ts.map +1 -1
- package/dist/commands/mcp-writers.js +6 -5
- package/dist/commands/mcp-writers.js.map +1 -1
- package/dist/commands/mcp.d.ts +1 -1
- package/dist/commands/mcp.d.ts.map +1 -1
- package/dist/commands/mcp.js +37 -9
- package/dist/commands/mcp.js.map +1 -1
- package/dist/commands/update.d.ts.map +1 -1
- package/dist/commands/update.js +16 -6
- package/dist/commands/update.js.map +1 -1
- package/dist/constants/cursor-globs.d.ts.map +1 -1
- package/dist/constants/cursor-globs.js +0 -6
- package/dist/constants/cursor-globs.js.map +1 -1
- package/dist/constants/ide-install-specs.js +9 -9
- package/dist/constants/ide-install-specs.js.map +1 -1
- package/dist/constants.d.ts +3 -3
- package/dist/constants.d.ts.map +1 -1
- package/dist/constants.js +3 -3
- package/dist/constants.js.map +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -9
- package/dist/index.js.map +1 -1
- package/dist/types/ide-install.js +1 -1
- package/dist/utils/copy-helpers.d.ts +7 -2
- package/dist/utils/copy-helpers.d.ts.map +1 -1
- package/dist/utils/copy-helpers.js +77 -51
- package/dist/utils/copy-helpers.js.map +1 -1
- package/dist/utils/install-manifest.d.ts +12 -0
- package/dist/utils/install-manifest.d.ts.map +1 -0
- package/dist/utils/install-manifest.js +27 -0
- package/dist/utils/install-manifest.js.map +1 -0
- package/dist/utils/validation.d.ts.map +1 -1
- package/dist/utils/validation.js +34 -7
- package/dist/utils/validation.js.map +1 -1
- package/package.json +5 -4
- package/.agent/core/embeddings.json +0 -2004
- package/.agent/core/session_cache.json +0 -50
- package/.agent/skills/cross-cutting/aws/META.yaml +0 -75
- package/.agent/skills/cross-cutting/ci-cd/META.yaml +0 -60
- package/.agent/skills/cross-cutting/docker/META.yaml +0 -65
- package/.agent/skills/cross-cutting/kubernetes/META.yaml +0 -70
- package/.agent/skills/cross-cutting/ui-ux-pro-max/SKILL.md +0 -565
- package/.agent/skills/cross-cutting/ui-ux-pro-max/data/charts.yaml +0 -331
- package/.agent/skills/cross-cutting/ui-ux-pro-max/data/colors.yaml +0 -1226
- package/.agent/skills/cross-cutting/ui-ux-pro-max/data/component-decision.yaml +0 -287
- package/.agent/skills/cross-cutting/ui-ux-pro-max/data/component-mapping.yaml +0 -318
- package/.agent/skills/cross-cutting/ui-ux-pro-max/data/design-tokens.yaml +0 -525
- package/.agent/skills/cross-cutting/ui-ux-pro-max/data/desktop-animation.yaml +0 -232
- package/.agent/skills/cross-cutting/ui-ux-pro-max/data/desktop-architecture.yaml +0 -140
- package/.agent/skills/cross-cutting/ui-ux-pro-max/data/directory-structure.yaml +0 -75
- package/.agent/skills/cross-cutting/ui-ux-pro-max/data/icons.yaml +0 -918
- package/.agent/skills/cross-cutting/ui-ux-pro-max/data/implementation-strategy.yaml +0 -107
- package/.agent/skills/cross-cutting/ui-ux-pro-max/data/landing.yaml +0 -372
- package/.agent/skills/cross-cutting/ui-ux-pro-max/data/platform-frameworks.yaml +0 -195
- package/.agent/skills/cross-cutting/ui-ux-pro-max/data/platform-guidelines.yaml +0 -177
- package/.agent/skills/cross-cutting/ui-ux-pro-max/data/products.yaml +0 -1339
- package/.agent/skills/cross-cutting/ui-ux-pro-max/data/prompts.yaml +0 -180
- package/.agent/skills/cross-cutting/ui-ux-pro-max/data/react-performance.yaml +0 -504
- package/.agent/skills/cross-cutting/ui-ux-pro-max/data/stacks/desktop.yaml +0 -228
- package/.agent/skills/cross-cutting/ui-ux-pro-max/data/stacks/flutter.yaml +0 -508
- package/.agent/skills/cross-cutting/ui-ux-pro-max/data/stacks/html-tailwind.yaml +0 -543
- package/.agent/skills/cross-cutting/ui-ux-pro-max/data/stacks/nextjs.yaml +0 -515
- package/.agent/skills/cross-cutting/ui-ux-pro-max/data/stacks/nuxt-ui.yaml +0 -519
- package/.agent/skills/cross-cutting/ui-ux-pro-max/data/stacks/nuxtjs.yaml +0 -599
- package/.agent/skills/cross-cutting/ui-ux-pro-max/data/stacks/react-native.yaml +0 -496
- package/.agent/skills/cross-cutting/ui-ux-pro-max/data/stacks/react.yaml +0 -526
- package/.agent/skills/cross-cutting/ui-ux-pro-max/data/stacks/shadcn.yaml +0 -616
- package/.agent/skills/cross-cutting/ui-ux-pro-max/data/stacks/svelte.yaml +0 -520
- package/.agent/skills/cross-cutting/ui-ux-pro-max/data/stacks/swiftui.yaml +0 -486
- package/.agent/skills/cross-cutting/ui-ux-pro-max/data/stacks/vue.yaml +0 -485
- package/.agent/skills/cross-cutting/ui-ux-pro-max/data/styles.yaml +0 -1473
- package/.agent/skills/cross-cutting/ui-ux-pro-max/data/typography.yaml +0 -647
- package/.agent/skills/cross-cutting/ui-ux-pro-max/data/ui-reasoning.yaml +0 -1019
- package/.agent/skills/cross-cutting/ui-ux-pro-max/data/ux-guidelines.yaml +0 -1009
- package/.agent/skills/cross-cutting/ui-ux-pro-max/data/web-interface.yaml +0 -347
- package/.agent/skills/cross-cutting/ui-ux-pro-max/scripts/__pycache__/core.cpython-310.pyc +0 -0
- package/.agent/skills/cross-cutting/ui-ux-pro-max/scripts/__pycache__/core.cpython-314.pyc +0 -0
- package/.agent/skills/cross-cutting/ui-ux-pro-max/scripts/__pycache__/design_system.cpython-314.pyc +0 -0
- package/.agent/skills/cross-cutting/ui-ux-pro-max/scripts/core.py +0 -393
- package/.agent/skills/cross-cutting/ui-ux-pro-max/scripts/core_legacy.py +0 -303
- package/.agent/skills/cross-cutting/ui-ux-pro-max/scripts/design_system.py +0 -496
- package/.agent/skills/cross-cutting/ui-ux-pro-max/scripts/search.py +0 -76
- package/.agent/skills/devops/aws/ADVANCED.md +0 -547
- package/.agent/skills/devops/ci-cd/ADVANCED.md +0 -529
- package/.agent/skills/devops/docker/ADVANCED.md +0 -495
- package/.agent/skills/devops/kubernetes/ADVANCED.md +0 -252
- /package/.agent/core/{ARCH_REGISTRY.yaml → reference/ARCH_REGISTRY.yaml} +0 -0
- /package/.agent/core/{BRANDING.yaml → reference/BRANDING.yaml} +0 -0
- /package/.agent/core/{HSA.yaml → reference/HSA.yaml} +0 -0
- /package/.agent/rules/{incremental-changes.md → archive/incremental-changes.md} +0 -0
- /package/.agent/rules/{shell-commands.md → archive/shell-commands.md} +0 -0
- /package/.agent/skills/{cross-cutting → devops}/aws/data/ai_ml.yaml +0 -0
- /package/.agent/skills/{cross-cutting → devops}/aws/data/compute.yaml +0 -0
- /package/.agent/skills/{cross-cutting → devops}/aws/data/kubernetes.yaml +0 -0
- /package/.agent/skills/{cross-cutting → devops}/aws/data/storage.yaml +0 -0
- /package/.agent/skills/{cross-cutting → devops}/ci-cd/data/github_actions.yaml +0 -0
- /package/.agent/skills/{cross-cutting → devops}/ci-cd/data/security.yaml +0 -0
- /package/.agent/skills/{cross-cutting → devops}/docker/data/build.yaml +0 -0
- /package/.agent/skills/{cross-cutting → devops}/docker/data/compose.yaml +0 -0
- /package/.agent/skills/{cross-cutting → devops}/docker/data/security.yaml +0 -0
- /package/.agent/skills/{cross-cutting → devops}/kubernetes/data/networking.yaml +0 -0
- /package/.agent/skills/{cross-cutting → devops}/kubernetes/data/scheduling.yaml +0 -0
- /package/.agent/skills/{cross-cutting → devops}/kubernetes/data/security.yaml +0 -0
- /package/.agent/skills/{cross-cutting → devops}/kubernetes/data/workloads.yaml +0 -0
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
# Language Server Protocol Patterns — HSA Tier 3 Data
|
|
2
|
+
version: "1.0.0"
|
|
3
|
+
|
|
4
|
+
patterns:
|
|
5
|
+
- id: LSP-001
|
|
6
|
+
name: Server Initialization
|
|
7
|
+
category: setup
|
|
8
|
+
description: LSP server setup with capabilities negotiation.
|
|
9
|
+
text: |
|
|
10
|
+
Server declares capabilities during initialize handshake.
|
|
11
|
+
Common capabilities: completion, hover, definition, references,
|
|
12
|
+
diagnostics, code actions, rename, formatting.
|
|
13
|
+
example: |
|
|
14
|
+
const connection = createConnection(ProtocoLConnection);
|
|
15
|
+
const documents = new TextDocuments(TextDocument);
|
|
16
|
+
connection.onInitialize((params) => ({
|
|
17
|
+
capabilities: {
|
|
18
|
+
textDocumentSync: TextDocumentSyncKind.Incremental,
|
|
19
|
+
completionProvider: { resolveProvider: true, triggerCharacters: ["."] },
|
|
20
|
+
hoverProvider: true,
|
|
21
|
+
definitionProvider: true,
|
|
22
|
+
referencesProvider: true,
|
|
23
|
+
codeActionProvider: true
|
|
24
|
+
}
|
|
25
|
+
}));
|
|
26
|
+
documents.listen(connection);
|
|
27
|
+
connection.listen();
|
|
28
|
+
|
|
29
|
+
- id: LSP-002
|
|
30
|
+
name: Diagnostics Push
|
|
31
|
+
category: analysis
|
|
32
|
+
description: Push diagnostics (errors/warnings) to client.
|
|
33
|
+
text: |
|
|
34
|
+
Send diagnostics on document change.
|
|
35
|
+
Include severity, range, message, source.
|
|
36
|
+
example: |
|
|
37
|
+
documents.onDidChangeContent((change) => {
|
|
38
|
+
const diagnostics: Diagnostic[] = [];
|
|
39
|
+
const text = change.document.getText();
|
|
40
|
+
// Analyze text, push diagnostics
|
|
41
|
+
const match = /TODO/.exec(text);
|
|
42
|
+
if (match) {
|
|
43
|
+
diagnostics.push({
|
|
44
|
+
severity: DiagnosticSeverity.Information,
|
|
45
|
+
range: { start: { line: 0, character: match.index },
|
|
46
|
+
end: { line: 0, character: match.index + 4 } },
|
|
47
|
+
message: "TODO found",
|
|
48
|
+
source: "my-lsp"
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
connection.sendDiagnostics({ uri: change.document.uri, diagnostics });
|
|
52
|
+
});
|
|
53
|
+
|
|
54
|
+
- id: LSP-003
|
|
55
|
+
name: Code Actions
|
|
56
|
+
category: refactoring
|
|
57
|
+
description: Quick fixes and refactoring actions.
|
|
58
|
+
text: |
|
|
59
|
+
Return CodeAction[] for given diagnostic context.
|
|
60
|
+
Types: QuickFix, Refactor, Source, Extract.
|
|
61
|
+
example: |
|
|
62
|
+
connection.onCodeAction((params) => {
|
|
63
|
+
const actions: CodeAction[] = [];
|
|
64
|
+
for (const diag of params.context.diagnostics) {
|
|
65
|
+
if (diag.code === "unused-import") {
|
|
66
|
+
actions.push({
|
|
67
|
+
title: "Remove unused import",
|
|
68
|
+
kind: CodeActionKind.QuickFix,
|
|
69
|
+
edit: { changes: { [params.textDocument.uri]: [TextEdit.del(diag.range)] } },
|
|
70
|
+
diagnostics: [diag]
|
|
71
|
+
});
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
return actions;
|
|
75
|
+
});
|
|
76
|
+
|
|
77
|
+
- id: LSP-004
|
|
78
|
+
name: Go-to-Definition
|
|
79
|
+
category: navigation
|
|
80
|
+
description: Jump to symbol definition.
|
|
81
|
+
example: |
|
|
82
|
+
connection.onDefinition((params) => {
|
|
83
|
+
const doc = documents.get(params.textDocument.uri);
|
|
84
|
+
const word = getWordAtPosition(doc, params.position);
|
|
85
|
+
const location = findDefinition(word);
|
|
86
|
+
return location ? Location.create(location.uri, location.range) : null;
|
|
87
|
+
});
|
|
88
|
+
|
|
89
|
+
- id: LSP-005
|
|
90
|
+
name: Hover Information
|
|
91
|
+
category: analysis
|
|
92
|
+
description: Show documentation on hover.
|
|
93
|
+
example: |
|
|
94
|
+
connection.onHover((params) => {
|
|
95
|
+
const doc = documents.get(params.textDocument.uri);
|
|
96
|
+
const word = getWordAtPosition(doc, params.position);
|
|
97
|
+
const info = getDocumentation(word);
|
|
98
|
+
return info ? { contents: { kind: "markdown", value: info } } : null;
|
|
99
|
+
});
|
|
100
|
+
|
|
101
|
+
- id: LSP-006
|
|
102
|
+
name: Transport Configuration
|
|
103
|
+
category: setup
|
|
104
|
+
description: |
|
|
105
|
+
LSP transport options: stdio (most common), IPC, TCP, pipe.
|
|
106
|
+
text: |
|
|
107
|
+
stdio: Default, works with all editors
|
|
108
|
+
IPC: VS Code–specific, faster
|
|
109
|
+
TCP: Remote debugging, network servers
|
|
110
|
+
|
|
111
|
+
Client launch config (VS Code):
|
|
112
|
+
"languageServer": {
|
|
113
|
+
"command": "node",
|
|
114
|
+
"args": ["./server/out/main.js", "--stdio"],
|
|
115
|
+
"transport": "stdio"
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
- id: LSP-007
|
|
119
|
+
name: Incremental Sync
|
|
120
|
+
category: performance
|
|
121
|
+
description: |
|
|
122
|
+
Use incremental text sync for large files.
|
|
123
|
+
text: |
|
|
124
|
+
TextDocumentSyncKind.Incremental sends only changed ranges.
|
|
125
|
+
TextDocumentSyncKind.Full sends entire document (simpler but slower).
|
|
126
|
+
Best practice: Use Incremental for production LSP servers.
|
|
@@ -0,0 +1,172 @@
|
|
|
1
|
+
# VS Code Extension Patterns — HSA Tier 3 Data
|
|
2
|
+
# IDE Extension Development Skill
|
|
3
|
+
version: "1.0.0"
|
|
4
|
+
|
|
5
|
+
patterns:
|
|
6
|
+
# ==========================================================================
|
|
7
|
+
# Extension Host Architecture
|
|
8
|
+
# ==========================================================================
|
|
9
|
+
- id: VSCODE-001
|
|
10
|
+
name: Extension Activation
|
|
11
|
+
category: lifecycle
|
|
12
|
+
description: |
|
|
13
|
+
Extensions run in isolated Extension Host process.
|
|
14
|
+
Use activation events to lazy-load.
|
|
15
|
+
text: |
|
|
16
|
+
Activation Events (package.json):
|
|
17
|
+
- onLanguage:typescript — When TS file opened
|
|
18
|
+
- onCommand:ext.cmd — When command invoked
|
|
19
|
+
- workspaceContains:**/*.rs — When workspace has Rust files
|
|
20
|
+
- onStartupFinished — After VS Code fully loaded (use sparingly)
|
|
21
|
+
- * — Always active (avoid: blocks startup)
|
|
22
|
+
example: |
|
|
23
|
+
// package.json
|
|
24
|
+
"activationEvents": ["onLanguage:python", "onCommand:ext.analyze"]
|
|
25
|
+
|
|
26
|
+
// extension.ts
|
|
27
|
+
export function activate(context: ExtensionContext) {
|
|
28
|
+
const cmd = commands.registerCommand("ext.analyze", async () => {
|
|
29
|
+
const editor = window.activeTextEditor;
|
|
30
|
+
if (!editor) return;
|
|
31
|
+
// ... analyze document
|
|
32
|
+
});
|
|
33
|
+
context.subscriptions.push(cmd);
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
- id: VSCODE-002
|
|
37
|
+
name: Contribution Points
|
|
38
|
+
category: api
|
|
39
|
+
description: |
|
|
40
|
+
Declarative UI contributions in package.json.
|
|
41
|
+
text: |
|
|
42
|
+
Key contribution points:
|
|
43
|
+
- commands: Register command palette entries
|
|
44
|
+
- menus: Context menus, editor title, explorer context
|
|
45
|
+
- views: Custom tree views in sidebar
|
|
46
|
+
- viewsContainers: Custom activity bar icons
|
|
47
|
+
- configuration: Settings page entries
|
|
48
|
+
- keybindings: Keyboard shortcuts
|
|
49
|
+
- languages: Language declarations
|
|
50
|
+
- grammars: TextMate grammar for syntax highlighting
|
|
51
|
+
- themes: Color themes
|
|
52
|
+
- snippets: Code snippets
|
|
53
|
+
|
|
54
|
+
- id: VSCODE-003
|
|
55
|
+
name: Webview Panel
|
|
56
|
+
category: ui
|
|
57
|
+
description: |
|
|
58
|
+
Custom HTML/CSS/JS UI in editor panels.
|
|
59
|
+
text: |
|
|
60
|
+
Best practices:
|
|
61
|
+
- Use message passing (postMessage/onDidReceiveMessage)
|
|
62
|
+
- Persist state with getState/setState
|
|
63
|
+
- Use webviewOptions.retainContextWhenHidden sparingly
|
|
64
|
+
- Apply CSP: default-src 'none'
|
|
65
|
+
- Use webview.asWebviewUri for local resources
|
|
66
|
+
example: |
|
|
67
|
+
const panel = window.createWebviewPanel(
|
|
68
|
+
"myView", "My Panel", ViewColumn.One,
|
|
69
|
+
{ enableScripts: true, retainContextWhenHidden: false }
|
|
70
|
+
);
|
|
71
|
+
panel.webview.html = getHtml(panel.webview);
|
|
72
|
+
panel.webview.onDidReceiveMessage((msg) => {
|
|
73
|
+
if (msg.command === "getData") {
|
|
74
|
+
panel.webview.postMessage({ data: result });
|
|
75
|
+
}
|
|
76
|
+
});
|
|
77
|
+
|
|
78
|
+
- id: VSCODE-004
|
|
79
|
+
name: TreeView Provider
|
|
80
|
+
category: ui
|
|
81
|
+
description: |
|
|
82
|
+
Custom tree views in sidebar/explorer.
|
|
83
|
+
text: |
|
|
84
|
+
Implement TreeDataProvider<T> interface:
|
|
85
|
+
- getChildren(element?): Return child nodes
|
|
86
|
+
- getTreeItem(element): Return TreeItem with label, icon, command
|
|
87
|
+
- onDidChangeTreeData: Event to refresh tree
|
|
88
|
+
example: |
|
|
89
|
+
class MyTreeProvider implements TreeDataProvider<MyItem> {
|
|
90
|
+
private _onDidChange = new EventEmitter<MyItem | undefined>();
|
|
91
|
+
readonly onDidChangeTreeData = this._onDidChange.event;
|
|
92
|
+
|
|
93
|
+
getChildren(el?: MyItem): MyItem[] {
|
|
94
|
+
return el ? el.children : this.rootItems;
|
|
95
|
+
}
|
|
96
|
+
getTreeItem(el: MyItem): TreeItem {
|
|
97
|
+
return { label: el.name, collapsibleState: el.children.length ? 1 : 0 };
|
|
98
|
+
}
|
|
99
|
+
refresh() { this._onDidChange.fire(undefined); }
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
- id: VSCODE-005
|
|
103
|
+
name: Extension Testing
|
|
104
|
+
category: testing
|
|
105
|
+
description: |
|
|
106
|
+
Test extensions in Extension Development Host.
|
|
107
|
+
text: |
|
|
108
|
+
Setup:
|
|
109
|
+
1. Use @vscode/test-electron for integration tests
|
|
110
|
+
2. Run tests in isolated VS Code instance
|
|
111
|
+
3. Use mocha as test runner
|
|
112
|
+
4. Mock vscode API for unit tests
|
|
113
|
+
example: |
|
|
114
|
+
// src/test/suite/extension.test.ts
|
|
115
|
+
suite("Extension Test Suite", () => {
|
|
116
|
+
test("Command should activate", async () => {
|
|
117
|
+
await vscode.commands.executeCommand("ext.doSomething");
|
|
118
|
+
assert.ok(true);
|
|
119
|
+
});
|
|
120
|
+
});
|
|
121
|
+
|
|
122
|
+
- id: VSCODE-006
|
|
123
|
+
name: Diagnostic Provider
|
|
124
|
+
category: api
|
|
125
|
+
description: |
|
|
126
|
+
Report errors/warnings in Problems panel.
|
|
127
|
+
text: |
|
|
128
|
+
Use DiagnosticCollection to manage diagnostics.
|
|
129
|
+
Update on document change events.
|
|
130
|
+
example: |
|
|
131
|
+
const diagnostics = languages.createDiagnosticCollection("myLinter");
|
|
132
|
+
workspace.onDidChangeTextDocument((e) => {
|
|
133
|
+
const diags: Diagnostic[] = [];
|
|
134
|
+
// analyze document, push Diagnostic objects
|
|
135
|
+
diagnostics.set(e.document.uri, diags);
|
|
136
|
+
});
|
|
137
|
+
|
|
138
|
+
- id: VSCODE-007
|
|
139
|
+
name: CompletionItem Provider
|
|
140
|
+
category: api
|
|
141
|
+
description: |
|
|
142
|
+
Provide autocomplete suggestions.
|
|
143
|
+
text: |
|
|
144
|
+
Register CompletionItemProvider with trigger characters.
|
|
145
|
+
Return CompletionItem[] with label, kind, detail, insertText.
|
|
146
|
+
example: |
|
|
147
|
+
languages.registerCompletionItemProvider("typescript", {
|
|
148
|
+
provideCompletionItems(doc, pos) {
|
|
149
|
+
const items: CompletionItem[] = [
|
|
150
|
+
{ label: "myFunction", kind: CompletionItemKind.Function,
|
|
151
|
+
insertText: new SnippetString("myFunction(${1:arg})"),
|
|
152
|
+
detail: "Custom function" }
|
|
153
|
+
];
|
|
154
|
+
return items;
|
|
155
|
+
}
|
|
156
|
+
}, ".");
|
|
157
|
+
|
|
158
|
+
- id: VSCODE-008
|
|
159
|
+
name: Publishing Extension
|
|
160
|
+
category: distribution
|
|
161
|
+
description: |
|
|
162
|
+
Package and publish to VS Code Marketplace.
|
|
163
|
+
text: |
|
|
164
|
+
Steps:
|
|
165
|
+
1. npm install -g @vscode/vsce
|
|
166
|
+
2. vsce package → creates .vsix
|
|
167
|
+
3. vsce publish → publishes to marketplace
|
|
168
|
+
Requirements:
|
|
169
|
+
- publisher in package.json
|
|
170
|
+
- Azure DevOps PAT token
|
|
171
|
+
- README.md with screenshots
|
|
172
|
+
- CHANGELOG.md
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
name: mcp
|
|
2
|
+
version: "1.0.0"
|
|
3
|
+
display: Model Context Protocol
|
|
4
|
+
category: tooling
|
|
5
|
+
tier: 1
|
|
6
|
+
priority: 1
|
|
7
|
+
|
|
8
|
+
desc: "MCP server & client development. JSON-RPC 2.0, transport (stdio/Streamable HTTP), tool/resource/prompt primitives, OAuth 2.1, and production patterns."
|
|
9
|
+
|
|
10
|
+
### Data Files (3 domains, ~24 patterns)
|
|
11
|
+
- transport-patterns.yaml: stdio vs Streamable HTTP, config (8)
|
|
12
|
+
- tool-design.yaml: stateless tools, pagination, error handling (8)
|
|
13
|
+
- security.yaml: OAuth 2.1 flows, input validation, rate limiting (8)
|
|
14
|
+
|
|
15
|
+
triggers:
|
|
16
|
+
file_patterns:
|
|
17
|
+
# Config
|
|
18
|
+
- "mcp.json"
|
|
19
|
+
- "mcp-config.json"
|
|
20
|
+
- ".mcp.json"
|
|
21
|
+
- "claude_desktop_config.json"
|
|
22
|
+
# Server structure
|
|
23
|
+
- "**/mcp-server/**"
|
|
24
|
+
- "**/mcp/**/*.ts"
|
|
25
|
+
- "**/tools/*.ts"
|
|
26
|
+
- "**/resources/*.ts"
|
|
27
|
+
- "**/prompts/*.ts"
|
|
28
|
+
keywords:
|
|
29
|
+
# Core
|
|
30
|
+
- MCP
|
|
31
|
+
- Model Context Protocol
|
|
32
|
+
- mcp server
|
|
33
|
+
- mcp client
|
|
34
|
+
- mcp tool
|
|
35
|
+
- mcp resource
|
|
36
|
+
- mcp prompt
|
|
37
|
+
# Protocol
|
|
38
|
+
- JSON-RPC
|
|
39
|
+
- JSON-RPC 2.0
|
|
40
|
+
- jsonrpc
|
|
41
|
+
# Transport
|
|
42
|
+
- stdio transport
|
|
43
|
+
- streamable http
|
|
44
|
+
- sse transport
|
|
45
|
+
# SDK
|
|
46
|
+
- "@modelcontextprotocol/sdk"
|
|
47
|
+
- "mcp sdk"
|
|
48
|
+
- "from mcp import"
|
|
49
|
+
# Primitives
|
|
50
|
+
- tool definition
|
|
51
|
+
- resource template
|
|
52
|
+
- prompt template
|
|
53
|
+
# Auth
|
|
54
|
+
- OAuth 2.1
|
|
55
|
+
- mcp auth
|
|
56
|
+
|
|
57
|
+
caps:
|
|
58
|
+
- JSON-RPC 2.0 protocol (request/response/notification)
|
|
59
|
+
- Host ↔ Client ↔ Server architecture
|
|
60
|
+
- Transport: stdio (local/dev) vs Streamable HTTP (remote/prod)
|
|
61
|
+
- Tool primitives: stateless, idempotent, JSON Schema validation
|
|
62
|
+
- Resource primitives: URI templates, dynamic content
|
|
63
|
+
- Prompt primitives: reusable prompt templates
|
|
64
|
+
- OAuth 2.1 authentication (mandatory for HTTP transport)
|
|
65
|
+
- Bounded context per server (single responsibility)
|
|
66
|
+
- Pagination tokens for large result sets
|
|
67
|
+
- Error classification (recoverable vs fatal, -32xxx codes)
|
|
68
|
+
- Input validation & sanitization
|
|
69
|
+
- Containerized deployment patterns
|
|
70
|
+
- SDK patterns: TypeScript (@modelcontextprotocol/sdk), Python (mcp)
|
|
71
|
+
|
|
72
|
+
related_skills:
|
|
73
|
+
- ai-agents
|
|
74
|
+
- api-protocols
|
|
75
|
+
- security
|
|
76
|
+
|
|
77
|
+
hsa_adapter:
|
|
78
|
+
enabled: true
|
|
79
|
+
data_dir: "skills/tooling/mcp/data"
|
|
80
|
+
preload_data: true
|
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
# MCP — Model Context Protocol Server Development
|
|
2
|
+
|
|
3
|
+
> Skill cho phát triển MCP servers & clients
|
|
4
|
+
> JSON-RPC 2.0 • Tool/Resource/Prompt primitives • OAuth 2.1
|
|
5
|
+
|
|
6
|
+
---
|
|
7
|
+
|
|
8
|
+
## Khi Nào Dùng
|
|
9
|
+
|
|
10
|
+
- Xây dựng MCP server kết nối AI agents với tools/data
|
|
11
|
+
- Phát triển custom tools, resources, prompts cho Claude/Gemini/ChatGPT
|
|
12
|
+
- Thiết kế transport layer (stdio local, Streamable HTTP production)
|
|
13
|
+
- Implement OAuth 2.1 cho MCP servers remote
|
|
14
|
+
|
|
15
|
+
## Architecture
|
|
16
|
+
|
|
17
|
+
```
|
|
18
|
+
┌─────────────────────────────────────────┐
|
|
19
|
+
│ HOST APPLICATION │
|
|
20
|
+
│ (Claude Desktop, VS Code, IDE...) │
|
|
21
|
+
│ │
|
|
22
|
+
│ ┌──────────┐ ┌──────────┐ │
|
|
23
|
+
│ │ Client A │ │ Client B │ ← 1:1 map │
|
|
24
|
+
│ └────┬─────┘ └────┬─────┘ │
|
|
25
|
+
└───────│──────────────│──────────────────┘
|
|
26
|
+
│ │
|
|
27
|
+
┌─────▼─────┐ ┌─────▼─────┐
|
|
28
|
+
│ Server A │ │ Server B │ ← Bounded context
|
|
29
|
+
│ (Files) │ │ (GitHub) │ ← Single responsibility
|
|
30
|
+
└───────────┘ └───────────┘
|
|
31
|
+
```
|
|
32
|
+
|
|
33
|
+
## Core Patterns
|
|
34
|
+
|
|
35
|
+
### Transport Selection
|
|
36
|
+
|
|
37
|
+
| Transport | Use Case | Auth |
|
|
38
|
+
| ------------------- | ---------------------------------- | ------------------ |
|
|
39
|
+
| **stdio** | Local dev, CLI tools, same-machine | Not required |
|
|
40
|
+
| **Streamable HTTP** | Remote, production, multi-user | OAuth 2.1 required |
|
|
41
|
+
|
|
42
|
+
### Tool Design (CRITICAL)
|
|
43
|
+
|
|
44
|
+
```typescript
|
|
45
|
+
// ✅ GOOD: Stateless, idempotent, bounded
|
|
46
|
+
server.tool(
|
|
47
|
+
"search_files",
|
|
48
|
+
{
|
|
49
|
+
query: z.string(),
|
|
50
|
+
maxResults: z.number().default(10),
|
|
51
|
+
},
|
|
52
|
+
async ({ query, maxResults }) => {
|
|
53
|
+
const results = await search(query, maxResults);
|
|
54
|
+
return { content: [{ type: "text", text: JSON.stringify(results) }] };
|
|
55
|
+
},
|
|
56
|
+
);
|
|
57
|
+
|
|
58
|
+
// ❌ BAD: Stateful, unbounded results
|
|
59
|
+
server.tool("get_all_data", {}, async () => {
|
|
60
|
+
return { content: [{ type: "text", text: entireDatabase }] }; // OOM!
|
|
61
|
+
});
|
|
62
|
+
```
|
|
63
|
+
|
|
64
|
+
### Tool Rules
|
|
65
|
+
|
|
66
|
+
1. **Stateless** — No side effects between calls
|
|
67
|
+
2. **Idempotent** — Same input → same output
|
|
68
|
+
3. **Bounded** — Use `maxResults` + pagination tokens
|
|
69
|
+
4. **Validated** — JSON Schema cho tất cả inputs
|
|
70
|
+
5. **Documented** — Clear description cho AI model
|
|
71
|
+
|
|
72
|
+
### Resource Design
|
|
73
|
+
|
|
74
|
+
```typescript
|
|
75
|
+
// Static resource
|
|
76
|
+
server.resource("config", "config://app", async () => ({
|
|
77
|
+
contents: [{ uri: "config://app", text: configData }],
|
|
78
|
+
}));
|
|
79
|
+
|
|
80
|
+
// Dynamic resource template
|
|
81
|
+
server.resourceTemplate("user/{id}", async (uri) => ({
|
|
82
|
+
contents: [{ uri, text: await getUser(uri.params.id) }],
|
|
83
|
+
}));
|
|
84
|
+
```
|
|
85
|
+
|
|
86
|
+
## Security Checklist
|
|
87
|
+
|
|
88
|
+
- ✅ OAuth 2.1 cho HTTP transport
|
|
89
|
+
- ✅ Input validation (JSON Schema)
|
|
90
|
+
- ✅ Response size limits
|
|
91
|
+
- ✅ Rate limiting per client
|
|
92
|
+
- ✅ No secrets in tool outputs
|
|
93
|
+
- ✅ Sanitize file paths (prevent traversal)
|
|
94
|
+
|
|
95
|
+
## Common Traps
|
|
96
|
+
|
|
97
|
+
| Trap | Giải pháp |
|
|
98
|
+
| -------------------- | -------------------------------------------- |
|
|
99
|
+
| Response quá lớn | Pagination tokens, `maxResults` |
|
|
100
|
+
| Timeout | Set timeout per tool, return partial results |
|
|
101
|
+
| Error classification | Use JSON-RPC error codes (-32600 to -32603) |
|
|
102
|
+
| Concurrent requests | Stateless design, no shared mutable state |
|
|
103
|
+
| Transport mismatch | stdio=dev only, HTTP=prod with OAuth |
|
|
104
|
+
|
|
105
|
+
## SDK Quick Reference
|
|
106
|
+
|
|
107
|
+
| Language | Package | Docs |
|
|
108
|
+
| ---------- | --------------------------- | ----------------------- |
|
|
109
|
+
| TypeScript | `@modelcontextprotocol/sdk` | modelcontextprotocol.io |
|
|
110
|
+
| Python | `mcp` | modelcontextprotocol.io |
|
|
111
|
+
|
|
112
|
+
---
|
|
113
|
+
|
|
114
|
+
_DOMYH Awesome Code • MCP Skill v1.0.0_
|
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
# MCP Security Patterns - HSA MCP Skill
|
|
2
|
+
# Updated: 2026-02-12
|
|
3
|
+
|
|
4
|
+
metadata:
|
|
5
|
+
skill: mcp
|
|
6
|
+
domain: security
|
|
7
|
+
version: "1.0.0"
|
|
8
|
+
updated: "2026-02-12"
|
|
9
|
+
patterns_count: 8
|
|
10
|
+
|
|
11
|
+
patterns:
|
|
12
|
+
- id: sec001
|
|
13
|
+
name: oauth21
|
|
14
|
+
category: security
|
|
15
|
+
description: OAuth 2.1 authentication for HTTP transport
|
|
16
|
+
text: oauth 2.1 authentication http transport authorization bearer token
|
|
17
|
+
example: |
|
|
18
|
+
// Server: validate OAuth token
|
|
19
|
+
app.use("/mcp", async (req, res, next) => {
|
|
20
|
+
const token = req.headers.authorization?.split("Bearer ")[1];
|
|
21
|
+
if (!token || !await validateToken(token)) {
|
|
22
|
+
return res.status(401).json({ error: "Unauthorized" });
|
|
23
|
+
}
|
|
24
|
+
next();
|
|
25
|
+
});
|
|
26
|
+
severity: CRITICAL
|
|
27
|
+
rule: "OAuth 2.1 is MANDATORY for HTTP transport"
|
|
28
|
+
|
|
29
|
+
- id: sec002
|
|
30
|
+
name: input_sanitization
|
|
31
|
+
category: security
|
|
32
|
+
description: Sanitize all user inputs to prevent injection
|
|
33
|
+
text: input sanitization injection prevention path traversal command injection
|
|
34
|
+
example: |
|
|
35
|
+
// Prevent path traversal
|
|
36
|
+
const safePath = path.resolve(baseDir, userPath);
|
|
37
|
+
if (!safePath.startsWith(baseDir)) throw new Error("Path traversal!");
|
|
38
|
+
// Prevent command injection
|
|
39
|
+
const safeArg = shellEscape(userInput);
|
|
40
|
+
severity: CRITICAL
|
|
41
|
+
|
|
42
|
+
- id: sec003
|
|
43
|
+
name: rate_limiting
|
|
44
|
+
category: security
|
|
45
|
+
description: Rate limiting per client to prevent abuse
|
|
46
|
+
text: rate limit throttle abuse prevention per client request limit
|
|
47
|
+
example: |
|
|
48
|
+
const limiter = new RateLimiter({ windowMs: 60000, max: 100 });
|
|
49
|
+
app.use("/mcp", limiter.middleware());
|
|
50
|
+
severity: HIGH
|
|
51
|
+
|
|
52
|
+
- id: sec004
|
|
53
|
+
name: response_size_limit
|
|
54
|
+
category: security
|
|
55
|
+
description: Limit response sizes to prevent OOM
|
|
56
|
+
text: response size limit out of memory prevent large payload
|
|
57
|
+
example: |
|
|
58
|
+
const MAX_RESPONSE_SIZE = 1024 * 1024; // 1MB
|
|
59
|
+
if (result.length > MAX_RESPONSE_SIZE) {
|
|
60
|
+
return { content: [{ type: "text",
|
|
61
|
+
text: `Result too large (${result.length} bytes). Use pagination.` }],
|
|
62
|
+
isError: true };
|
|
63
|
+
}
|
|
64
|
+
severity: HIGH
|
|
65
|
+
|
|
66
|
+
- id: sec005
|
|
67
|
+
name: secrets_protection
|
|
68
|
+
category: security
|
|
69
|
+
description: Never expose secrets in tool outputs
|
|
70
|
+
text: secrets protection api keys passwords environment variables
|
|
71
|
+
rule: "NEVER include API keys, passwords, or tokens in tool responses"
|
|
72
|
+
example: |
|
|
73
|
+
// ✅ Redact secrets
|
|
74
|
+
const safeConfig = { ...config, apiKey: "***REDACTED***" };
|
|
75
|
+
// ❌ NEVER do this
|
|
76
|
+
return { content: [{ type: "text", text: process.env.API_KEY }] };
|
|
77
|
+
severity: CRITICAL
|
|
78
|
+
|
|
79
|
+
- id: sec006
|
|
80
|
+
name: scope_limitation
|
|
81
|
+
category: security
|
|
82
|
+
description: Limit server capabilities to minimal required scope
|
|
83
|
+
text: scope limitation minimal permissions principle of least privilege
|
|
84
|
+
rule: "Each server should only access what it needs"
|
|
85
|
+
example: |
|
|
86
|
+
// ✅ Read-only database server
|
|
87
|
+
server.tool("query", schema, async (input) => {
|
|
88
|
+
return db.query(input.sql); // SELECT only, no mutations
|
|
89
|
+
});
|
|
90
|
+
|
|
91
|
+
- id: sec007
|
|
92
|
+
name: timeout_handling
|
|
93
|
+
category: security
|
|
94
|
+
description: Set timeouts for all tool operations
|
|
95
|
+
text: timeout handling abort signal cancel long running operation
|
|
96
|
+
example: |
|
|
97
|
+
server.tool("fetch_data", schema, async (input) => {
|
|
98
|
+
const controller = new AbortController();
|
|
99
|
+
const timeout = setTimeout(() => controller.abort(), 30000);
|
|
100
|
+
try {
|
|
101
|
+
return await fetchData(input, { signal: controller.signal });
|
|
102
|
+
} finally { clearTimeout(timeout); }
|
|
103
|
+
});
|
|
104
|
+
severity: HIGH
|
|
105
|
+
|
|
106
|
+
- id: sec008
|
|
107
|
+
name: logging_audit
|
|
108
|
+
category: security
|
|
109
|
+
description: Audit logging for all tool invocations
|
|
110
|
+
text: logging audit trail tool invocation tracking
|
|
111
|
+
example: |
|
|
112
|
+
server.tool("write_file", schema, async (input) => {
|
|
113
|
+
logger.info({ tool: "write_file", input: sanitize(input), timestamp: Date.now() });
|
|
114
|
+
return await writeFile(input);
|
|
115
|
+
});
|
|
116
|
+
severity: MEDIUM
|