@ngxtm/devkit 3.0.2 → 3.1.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/package.json +1 -1
- package/skills/SPDD/1-research.md +22 -0
- package/skills/SPDD/2-spec.md +20 -0
- package/skills/SPDD/3-implementation.md +20 -0
- package/skills/accessibility-compliance-accessibility-audit/SKILL.md +42 -0
- package/skills/accessibility-compliance-accessibility-audit/resources/implementation-playbook.md +502 -0
- package/skills/active-directory-attacks/references/advanced-attacks.md +382 -382
- package/skills/agent-framework-azure-hosted-agents/SKILL.md +0 -3
- package/skills/agent-orchestration-improve-agent/SKILL.md +349 -0
- package/skills/agent-orchestration-multi-agent-optimize/SKILL.md +239 -0
- package/skills/ai-engineer/SKILL.md +171 -0
- package/skills/airflow-dag-patterns/SKILL.md +41 -0
- package/skills/airflow-dag-patterns/resources/implementation-playbook.md +509 -0
- package/skills/angular-migration/SKILL.md +428 -0
- package/skills/anti-reversing-techniques/SKILL.md +42 -0
- package/skills/anti-reversing-techniques/resources/implementation-playbook.md +539 -0
- package/skills/api-design-principles/SKILL.md +37 -0
- package/skills/api-design-principles/assets/api-design-checklist.md +155 -0
- package/skills/api-design-principles/assets/rest-api-template.py +182 -0
- package/skills/api-design-principles/references/graphql-schema-design.md +583 -0
- package/skills/api-design-principles/references/rest-best-practices.md +408 -0
- package/skills/api-design-principles/resources/implementation-playbook.md +513 -0
- package/skills/api-documenter/SKILL.md +184 -0
- package/skills/api-testing-observability-api-mock/SKILL.md +46 -0
- package/skills/api-testing-observability-api-mock/resources/implementation-playbook.md +1327 -0
- package/skills/application-performance-performance-optimization/SKILL.md +154 -0
- package/skills/architect-review/SKILL.md +174 -0
- package/skills/architecture-decision-records/SKILL.md +441 -0
- package/skills/architecture-patterns/SKILL.md +37 -0
- package/skills/architecture-patterns/resources/implementation-playbook.md +479 -0
- package/skills/arm-cortex-expert/SKILL.md +306 -0
- package/skills/artifacts-builder/scripts/bundle-artifact.sh +0 -0
- package/skills/artifacts-builder/scripts/init-artifact.sh +0 -0
- package/skills/async-python-patterns/SKILL.md +39 -0
- package/skills/async-python-patterns/resources/implementation-playbook.md +678 -0
- package/skills/attack-tree-construction/SKILL.md +38 -0
- package/skills/attack-tree-construction/resources/implementation-playbook.md +671 -0
- package/skills/auth-implementation-patterns/SKILL.md +39 -0
- package/skills/auth-implementation-patterns/resources/implementation-playbook.md +633 -0
- package/skills/automate-whatsapp/SKILL.md +257 -0
- package/skills/aws-agentic-ai/services/gateway/deploy-template.sh +0 -0
- package/skills/aws-agentic-ai/services/gateway/validate-deployment.sh +0 -0
- package/skills/aws-cdk-development/scripts/validate-stack.sh +0 -0
- package/skills/aws-penetration-testing/references/advanced-aws-pentesting.md +469 -469
- package/skills/aws-skills/SKILL.md +22 -0
- package/skills/azd-deployment/SKILL.md +0 -2
- package/skills/backend-architect/SKILL.md +333 -0
- package/skills/backend-development-feature-development/SKILL.md +180 -0
- package/skills/backend-security-coder/SKILL.md +156 -0
- package/skills/backtesting-frameworks/SKILL.md +39 -0
- package/skills/backtesting-frameworks/resources/implementation-playbook.md +647 -0
- package/skills/bash-defensive-patterns/SKILL.md +43 -0
- package/skills/bash-defensive-patterns/resources/implementation-playbook.md +517 -0
- package/skills/bash-pro/SKILL.md +310 -0
- package/skills/bats-testing-patterns/SKILL.md +34 -0
- package/skills/bats-testing-patterns/resources/implementation-playbook.md +614 -0
- package/skills/bazel-build-optimization/SKILL.md +397 -0
- package/skills/beautiful-prose/SKILL.md +22 -0
- package/skills/billing-automation/SKILL.md +42 -0
- package/skills/billing-automation/resources/implementation-playbook.md +544 -0
- package/skills/binary-analysis-patterns/SKILL.md +450 -0
- package/skills/blockchain-developer/SKILL.md +208 -0
- package/skills/business-analyst/SKILL.md +182 -0
- package/skills/c-pro/SKILL.md +56 -0
- package/skills/c4-architecture-c4-architecture/SKILL.md +389 -0
- package/skills/c4-code/SKILL.md +244 -0
- package/skills/c4-component/SKILL.md +153 -0
- package/skills/c4-container/SKILL.md +171 -0
- package/skills/c4-context/SKILL.md +150 -0
- package/skills/cc-skill-continuous-learning/evaluate-session.sh +0 -0
- package/skills/cc-skill-strategic-compact/suggest-compact.sh +0 -0
- package/skills/changelog-automation/SKILL.md +38 -0
- package/skills/changelog-automation/resources/implementation-playbook.md +538 -0
- package/skills/cicd-automation-workflow-automate/SKILL.md +51 -0
- package/skills/cicd-automation-workflow-automate/resources/implementation-playbook.md +1333 -0
- package/skills/clarity-gate/SKILL.md +22 -0
- package/skills/claude-ally-health/SKILL.md +22 -0
- package/skills/claude-scientific-skills/SKILL.md +22 -0
- package/skills/claude-speed-reader/SKILL.md +22 -0
- package/skills/claude-win11-speckit-update-skill/SKILL.md +22 -0
- package/skills/cloud-architect/SKILL.md +131 -102
- package/skills/cloud-penetration-testing/references/advanced-cloud-scripts.md +318 -318
- package/skills/code-documentation-code-explain/SKILL.md +46 -0
- package/skills/code-documentation-code-explain/resources/implementation-playbook.md +802 -0
- package/skills/code-documentation-doc-generate/SKILL.md +48 -0
- package/skills/code-documentation-doc-generate/resources/implementation-playbook.md +640 -0
- package/skills/code-refactoring-context-restore/SKILL.md +179 -0
- package/skills/code-refactoring-refactor-clean/SKILL.md +51 -0
- package/skills/code-refactoring-refactor-clean/resources/implementation-playbook.md +879 -0
- package/skills/code-refactoring-tech-debt/SKILL.md +386 -0
- package/skills/code-review-ai-ai-review/SKILL.md +450 -0
- package/skills/code-review-excellence/SKILL.md +40 -0
- package/skills/code-review-excellence/resources/implementation-playbook.md +515 -0
- package/skills/code-reviewer/SKILL.md +174 -205
- package/skills/codebase-cleanup-deps-audit/SKILL.md +51 -0
- package/skills/codebase-cleanup-deps-audit/resources/implementation-playbook.md +766 -0
- package/skills/codebase-cleanup-refactor-clean/SKILL.md +51 -0
- package/skills/codebase-cleanup-refactor-clean/resources/implementation-playbook.md +879 -0
- package/skills/codebase-cleanup-tech-debt/SKILL.md +386 -0
- package/skills/commit/SKILL.md +171 -0
- package/skills/competitive-landscape/SKILL.md +34 -0
- package/skills/competitive-landscape/resources/implementation-playbook.md +494 -0
- package/skills/comprehensive-review-full-review/SKILL.md +146 -0
- package/skills/comprehensive-review-pr-enhance/SKILL.md +46 -0
- package/skills/comprehensive-review-pr-enhance/resources/implementation-playbook.md +691 -0
- package/skills/conductor-implement/SKILL.md +388 -0
- package/skills/conductor-manage/SKILL.md +39 -0
- package/skills/conductor-manage/resources/implementation-playbook.md +1120 -0
- package/skills/conductor-new-track/SKILL.md +433 -0
- package/skills/conductor-revert/SKILL.md +372 -0
- package/skills/conductor-setup/SKILL.md +426 -0
- package/skills/conductor-status/SKILL.md +338 -0
- package/skills/conductor-validator/SKILL.md +62 -0
- package/skills/content-marketer/SKILL.md +170 -0
- package/skills/context-compression/SKILL.md +266 -0
- package/skills/context-degradation/SKILL.md +238 -0
- package/skills/context-driven-development/SKILL.md +400 -0
- package/skills/context-fundamentals/SKILL.md +192 -0
- package/skills/context-management-context-restore/SKILL.md +179 -0
- package/skills/context-management-context-save/SKILL.md +177 -0
- package/skills/context-manager/SKILL.md +185 -0
- package/skills/context-optimization/SKILL.md +186 -0
- package/skills/cost-optimization/SKILL.md +286 -0
- package/skills/cpp-pro/SKILL.md +42 -80
- package/skills/cqrs-implementation/SKILL.md +35 -0
- package/skills/cqrs-implementation/resources/implementation-playbook.md +540 -0
- package/skills/create-pr/SKILL.md +192 -0
- package/skills/csharp-pro/SKILL.md +59 -0
- package/skills/culture-index/SKILL.md +43 -0
- package/skills/customer-support/SKILL.md +170 -0
- package/skills/daily-news-report/SKILL.md +178 -179
- package/skills/data-engineer/SKILL.md +224 -0
- package/skills/data-engineering-data-driven-feature/SKILL.md +182 -0
- package/skills/data-engineering-data-pipeline/SKILL.md +201 -0
- package/skills/data-quality-frameworks/SKILL.md +40 -0
- package/skills/data-quality-frameworks/resources/implementation-playbook.md +573 -0
- package/skills/data-scientist/SKILL.md +199 -0
- package/skills/data-storytelling/SKILL.md +465 -0
- package/skills/database-admin/SKILL.md +165 -0
- package/skills/database-architect/SKILL.md +268 -0
- package/skills/database-cloud-optimization-cost-optimize/SKILL.md +44 -0
- package/skills/database-cloud-optimization-cost-optimize/resources/implementation-playbook.md +1441 -0
- package/skills/database-migration/SKILL.md +436 -0
- package/skills/database-migrations-migration-observability/SKILL.md +420 -0
- package/skills/database-migrations-sql-migrations/SKILL.md +53 -0
- package/skills/database-migrations-sql-migrations/resources/implementation-playbook.md +499 -0
- package/skills/database-optimizer/SKILL.md +163 -91
- package/skills/dbt-transformation-patterns/SKILL.md +34 -0
- package/skills/dbt-transformation-patterns/resources/implementation-playbook.md +547 -0
- package/skills/debugger/SKILL.md +49 -0
- package/skills/debugging-strategies/SKILL.md +34 -0
- package/skills/debugging-strategies/resources/implementation-playbook.md +511 -0
- package/skills/debugging-toolkit-smart-debug/SKILL.md +197 -0
- package/skills/deep-research/SKILL.md +114 -0
- package/skills/defi-protocol-templates/SKILL.md +466 -0
- package/skills/dependency-management-deps-audit/SKILL.md +44 -0
- package/skills/dependency-management-deps-audit/resources/implementation-playbook.md +766 -0
- package/skills/dependency-upgrade/SKILL.md +421 -0
- package/skills/deployment-engineer/SKILL.md +170 -0
- package/skills/deployment-pipeline-design/SKILL.md +371 -0
- package/skills/deployment-validation-config-validate/SKILL.md +496 -0
- package/skills/design-md/SKILL.md +178 -0
- package/skills/devops-troubleshooter/SKILL.md +161 -0
- package/skills/distributed-debugging-debug-trace/SKILL.md +44 -0
- package/skills/distributed-debugging-debug-trace/resources/implementation-playbook.md +1307 -0
- package/skills/distributed-tracing/SKILL.md +450 -0
- package/skills/django-pro/SKILL.md +180 -0
- package/skills/docs-architect/SKILL.md +98 -0
- package/skills/document-skills/docx/ooxml/scripts/pack.py +0 -0
- package/skills/document-skills/docx/ooxml/scripts/unpack.py +0 -0
- package/skills/document-skills/docx/ooxml/scripts/validate.py +0 -0
- package/skills/document-skills/docx/scripts/__init__.py +0 -0
- package/skills/document-skills/docx/scripts/document.py +0 -0
- package/skills/document-skills/docx/scripts/utilities.py +0 -0
- package/skills/document-skills/pptx/ooxml/scripts/pack.py +0 -0
- package/skills/document-skills/pptx/ooxml/scripts/unpack.py +0 -0
- package/skills/document-skills/pptx/ooxml/scripts/validate.py +0 -0
- package/skills/document-skills/pptx/scripts/html2pptx.js +0 -0
- package/skills/document-skills/pptx/scripts/inventory.py +0 -0
- package/skills/document-skills/pptx/scripts/rearrange.py +0 -0
- package/skills/document-skills/pptx/scripts/replace.py +0 -0
- package/skills/document-skills/pptx/scripts/thumbnail.py +0 -0
- package/skills/documentation-generation-doc-generate/SKILL.md +48 -0
- package/skills/documentation-generation-doc-generate/resources/implementation-playbook.md +640 -0
- package/skills/docx/LICENSE.txt +30 -0
- package/skills/docx/SKILL.md +172 -69
- package/skills/docx/docx-js.md +350 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -0
- package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -0
- package/skills/docx/ooxml/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -0
- package/skills/docx/ooxml/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -0
- package/skills/docx/ooxml/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -0
- package/skills/docx/ooxml/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -0
- package/skills/docx/ooxml/schemas/mce/mc.xsd +75 -0
- package/skills/docx/ooxml/schemas/microsoft/wml-2010.xsd +560 -0
- package/skills/docx/ooxml/schemas/microsoft/wml-2012.xsd +67 -0
- package/skills/docx/ooxml/schemas/microsoft/wml-2018.xsd +14 -0
- package/skills/docx/ooxml/schemas/microsoft/wml-cex-2018.xsd +20 -0
- package/skills/docx/ooxml/schemas/microsoft/wml-cid-2016.xsd +13 -0
- package/skills/docx/ooxml/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -0
- package/skills/docx/ooxml/schemas/microsoft/wml-symex-2015.xsd +8 -0
- package/skills/docx/ooxml/scripts/pack.py +159 -0
- package/skills/docx/ooxml/scripts/unpack.py +29 -0
- package/skills/docx/ooxml/scripts/validate.py +69 -0
- package/skills/docx/ooxml/scripts/validation/__init__.py +15 -0
- package/skills/docx/ooxml/scripts/validation/base.py +951 -0
- package/skills/docx/ooxml/scripts/validation/docx.py +274 -0
- package/skills/docx/ooxml/scripts/validation/pptx.py +315 -0
- package/skills/docx/ooxml/scripts/validation/redlining.py +279 -0
- package/skills/docx/ooxml.md +610 -0
- package/skills/docx/scripts/__init__.py +1 -0
- package/skills/docx/scripts/document.py +1276 -0
- package/skills/docx/scripts/templates/comments.xml +3 -0
- package/skills/docx/scripts/templates/commentsExtended.xml +3 -0
- package/skills/docx/scripts/templates/commentsExtensible.xml +3 -0
- package/skills/docx/scripts/templates/commentsIds.xml +3 -0
- package/skills/docx/scripts/templates/people.xml +3 -0
- package/skills/docx/scripts/utilities.py +374 -0
- package/skills/docx-official/ooxml/scripts/pack.py +0 -0
- package/skills/docx-official/ooxml/scripts/unpack.py +0 -0
- package/skills/docx-official/ooxml/scripts/validate.py +0 -0
- package/skills/docx-official/scripts/__init__.py +0 -0
- package/skills/docx-official/scripts/document.py +0 -0
- package/skills/docx-official/scripts/utilities.py +0 -0
- package/skills/dotnet-architect/SKILL.md +197 -0
- package/skills/dotnet-backend-patterns/SKILL.md +37 -0
- package/skills/dotnet-backend-patterns/assets/repository-template.cs +523 -0
- package/skills/dotnet-backend-patterns/assets/service-template.cs +336 -0
- package/skills/dotnet-backend-patterns/references/dapper-patterns.md +544 -0
- package/skills/dotnet-backend-patterns/references/ef-core-best-practices.md +355 -0
- package/skills/dotnet-backend-patterns/resources/implementation-playbook.md +799 -0
- package/skills/dx-optimizer/SKILL.md +83 -0
- package/skills/e2e-testing-patterns/SKILL.md +41 -0
- package/skills/e2e-testing-patterns/resources/implementation-playbook.md +531 -0
- package/skills/elixir-pro/SKILL.md +59 -0
- package/skills/embedding-strategies/SKILL.md +491 -0
- package/skills/employment-contract-templates/SKILL.md +39 -0
- package/skills/employment-contract-templates/resources/implementation-playbook.md +493 -0
- package/skills/error-debugging-error-analysis/SKILL.md +47 -0
- package/skills/error-debugging-error-analysis/resources/implementation-playbook.md +1143 -0
- package/skills/error-debugging-error-trace/SKILL.md +43 -0
- package/skills/error-debugging-error-trace/resources/implementation-playbook.md +1361 -0
- package/skills/error-debugging-multi-agent-review/SKILL.md +216 -0
- package/skills/error-detective/SKILL.md +53 -0
- package/skills/error-diagnostics-error-analysis/SKILL.md +47 -0
- package/skills/error-diagnostics-error-analysis/resources/implementation-playbook.md +1143 -0
- package/skills/error-diagnostics-error-trace/SKILL.md +48 -0
- package/skills/error-diagnostics-error-trace/resources/implementation-playbook.md +1371 -0
- package/skills/error-diagnostics-smart-debug/SKILL.md +197 -0
- package/skills/error-handling-patterns/SKILL.md +35 -0
- package/skills/error-handling-patterns/resources/implementation-playbook.md +635 -0
- package/skills/evaluation/SKILL.md +238 -0
- package/skills/event-sourcing-architect/SKILL.md +58 -0
- package/skills/event-store-design/SKILL.md +449 -0
- package/skills/expo-deployment/SKILL.md +62 -12
- package/skills/fal-audio/SKILL.md +22 -0
- package/skills/fal-generate/SKILL.md +22 -0
- package/skills/fal-image-edit/SKILL.md +22 -0
- package/skills/fal-platform/SKILL.md +22 -0
- package/skills/fal-upscale/SKILL.md +22 -0
- package/skills/fal-workflow/SKILL.md +22 -0
- package/skills/fastapi-pro/SKILL.md +192 -0
- package/skills/fastapi-templates/SKILL.md +32 -0
- package/skills/fastapi-templates/resources/implementation-playbook.md +566 -0
- package/skills/ffuf-claude-skill/SKILL.md +22 -0
- package/skills/find-bugs/SKILL.md +86 -0
- package/skills/firmware-analyst/SKILL.md +320 -0
- package/skills/fix-review/SKILL.md +53 -0
- package/skills/flutter-expert/SKILL.md +196 -84
- package/skills/foundry-iq-agent/SKILL.md +15 -0
- package/skills/foundry-iq-python/SKILL.md +0 -3
- package/skills/fp-ts-errors/SKILL.md +856 -0
- package/skills/fp-ts-pragmatic/SKILL.md +598 -0
- package/skills/fp-ts-react/SKILL.md +796 -0
- package/skills/framework-migration-code-migrate/SKILL.md +48 -0
- package/skills/framework-migration-code-migrate/resources/implementation-playbook.md +1052 -0
- package/skills/framework-migration-deps-upgrade/SKILL.md +48 -0
- package/skills/framework-migration-deps-upgrade/resources/implementation-playbook.md +755 -0
- package/skills/framework-migration-legacy-modernize/SKILL.md +132 -0
- package/skills/frontend-developer/SKILL.md +171 -0
- package/skills/frontend-mobile-development-component-scaffold/SKILL.md +403 -0
- package/skills/frontend-mobile-security-xss-scan/SKILL.md +322 -0
- package/skills/frontend-security-coder/SKILL.md +170 -0
- package/skills/frontend-slides/SKILL.md +770 -0
- package/skills/full-stack-orchestration-full-stack-feature/SKILL.md +135 -0
- package/skills/gdpr-data-handling/SKILL.md +33 -0
- package/skills/gdpr-data-handling/resources/implementation-playbook.md +615 -0
- package/skills/git-advanced-workflows/SKILL.md +412 -0
- package/skills/git-pr-workflows-git-workflow/SKILL.md +140 -0
- package/skills/git-pr-workflows-onboard/SKILL.md +416 -0
- package/skills/git-pr-workflows-pr-enhance/SKILL.md +48 -0
- package/skills/git-pr-workflows-pr-enhance/resources/implementation-playbook.md +701 -0
- package/skills/github-actions-templates/SKILL.md +345 -0
- package/skills/gitlab-ci-patterns/SKILL.md +283 -0
- package/skills/gitops-workflow/SKILL.md +303 -0
- package/skills/gitops-workflow/references/argocd-setup.md +134 -0
- package/skills/gitops-workflow/references/sync-policies.md +131 -0
- package/skills/go-concurrency-patterns/SKILL.md +33 -0
- package/skills/go-concurrency-patterns/resources/implementation-playbook.md +654 -0
- package/skills/godot-gdscript-patterns/SKILL.md +33 -0
- package/skills/godot-gdscript-patterns/resources/implementation-playbook.md +804 -0
- package/skills/golang-pro/SKILL.md +176 -91
- package/skills/grafana-dashboards/SKILL.md +381 -0
- package/skills/graphql-architect/SKILL.md +168 -83
- package/skills/haskell-pro/SKILL.md +56 -0
- package/skills/helm-chart-scaffolding/SKILL.md +34 -0
- package/skills/helm-chart-scaffolding/assets/Chart.yaml.template +42 -0
- package/skills/helm-chart-scaffolding/assets/values.yaml.template +185 -0
- package/skills/helm-chart-scaffolding/references/chart-structure.md +500 -0
- package/skills/helm-chart-scaffolding/resources/implementation-playbook.md +543 -0
- package/skills/helm-chart-scaffolding/scripts/validate-chart.sh +244 -0
- package/skills/hr-pro/SKILL.md +126 -0
- package/skills/hugging-face-cli/SKILL.md +198 -0
- package/skills/hugging-face-jobs/SKILL.md +1038 -0
- package/skills/hybrid-cloud-architect/SKILL.md +168 -0
- package/skills/hybrid-cloud-networking/SKILL.md +238 -0
- package/skills/hybrid-search-implementation/SKILL.md +32 -0
- package/skills/hybrid-search-implementation/resources/implementation-playbook.md +567 -0
- package/skills/imagen/SKILL.md +77 -0
- package/skills/incident-responder/SKILL.md +213 -0
- package/skills/incident-response-incident-response/SKILL.md +168 -0
- package/skills/incident-response-smart-fix/SKILL.md +29 -0
- package/skills/incident-response-smart-fix/resources/implementation-playbook.md +838 -0
- package/skills/incident-runbook-templates/SKILL.md +395 -0
- package/skills/infinite-gratitude/SKILL.md +26 -0
- package/skills/ios-developer/SKILL.md +219 -0
- package/skills/istio-traffic-management/SKILL.md +337 -0
- package/skills/iterate-pr/SKILL.md +150 -0
- package/skills/java-pro/SKILL.md +177 -0
- package/skills/javascript-pro/SKILL.md +41 -79
- package/skills/javascript-testing-patterns/SKILL.md +35 -0
- package/skills/javascript-testing-patterns/resources/implementation-playbook.md +1024 -0
- package/skills/javascript-typescript-typescript-scaffold/SKILL.md +361 -0
- package/skills/julia-pro/SKILL.md +209 -0
- package/skills/k8s-manifest-generator/SKILL.md +35 -0
- package/skills/k8s-manifest-generator/assets/configmap-template.yaml +296 -0
- package/skills/k8s-manifest-generator/assets/deployment-template.yaml +203 -0
- package/skills/k8s-manifest-generator/assets/service-template.yaml +171 -0
- package/skills/k8s-manifest-generator/references/deployment-spec.md +753 -0
- package/skills/k8s-manifest-generator/references/service-spec.md +724 -0
- package/skills/k8s-manifest-generator/resources/implementation-playbook.md +510 -0
- package/skills/k8s-security-policies/SKILL.md +346 -0
- package/skills/k8s-security-policies/assets/network-policy-template.yaml +177 -0
- package/skills/k8s-security-policies/references/rbac-patterns.md +187 -0
- package/skills/kpi-dashboard-design/SKILL.md +440 -0
- package/skills/kubernetes-architect/SKILL.md +170 -0
- package/skills/langchain-architecture/SKILL.md +350 -0
- package/skills/legacy-modernizer/SKILL.md +39 -79
- package/skills/legal-advisor/SKILL.md +70 -0
- package/skills/linear-claude-skill/SKILL.md +543 -0
- package/skills/linkerd-patterns/SKILL.md +321 -0
- package/skills/llm-application-dev-ai-assistant/SKILL.md +35 -0
- package/skills/llm-application-dev-ai-assistant/resources/implementation-playbook.md +1236 -0
- package/skills/llm-application-dev-langchain-agent/SKILL.md +246 -0
- package/skills/llm-application-dev-prompt-optimize/SKILL.md +37 -0
- package/skills/llm-application-dev-prompt-optimize/resources/implementation-playbook.md +591 -0
- package/skills/llm-evaluation/SKILL.md +483 -0
- package/skills/loki-mode/autonomy/run.sh +0 -0
- package/skills/loki-mode/benchmarks/prepare-submission.sh +0 -0
- package/skills/loki-mode/benchmarks/run-benchmarks.sh +0 -0
- package/skills/loki-mode/demo/record-demo.sh +0 -0
- package/skills/loki-mode/demo/record-full-demo.sh +0 -0
- package/skills/loki-mode/demo/run-demo-auto.sh +0 -0
- package/skills/loki-mode/demo/run-demo.sh +0 -0
- package/skills/loki-mode/scripts/export-to-vibe-kanban.sh +0 -0
- package/skills/loki-mode/scripts/loki-wrapper.sh +0 -0
- package/skills/loki-mode/tests/run-all-tests.sh +0 -0
- package/skills/loki-mode/tests/test-agent-timeout.sh +0 -0
- package/skills/loki-mode/tests/test-bootstrap.sh +0 -0
- package/skills/loki-mode/tests/test-circuit-breaker.sh +0 -0
- package/skills/loki-mode/tests/test-state-recovery.sh +0 -0
- package/skills/loki-mode/tests/test-task-queue.sh +0 -0
- package/skills/loki-mode/tests/test-wrapper.sh +0 -0
- package/skills/machine-learning-ops-ml-pipeline/SKILL.md +314 -0
- package/skills/makepad-skills/SKILL.md +22 -0
- package/skills/malware-analyst/SKILL.md +247 -0
- package/skills/market-sizing-analysis/SKILL.md +425 -0
- package/skills/market-sizing-analysis/examples/saas-market-sizing.md +349 -0
- package/skills/market-sizing-analysis/references/data-sources.md +360 -0
- package/skills/memory-forensics/SKILL.md +491 -0
- package/skills/memory-safety-patterns/SKILL.md +33 -0
- package/skills/memory-safety-patterns/resources/implementation-playbook.md +603 -0
- package/skills/memory-systems/SKILL.md +228 -0
- package/skills/mermaid-expert/SKILL.md +59 -0
- package/skills/microservices-patterns/SKILL.md +35 -0
- package/skills/microservices-patterns/resources/implementation-playbook.md +607 -0
- package/skills/minecraft-bukkit-pro/SKILL.md +126 -0
- package/skills/ml-engineer/SKILL.md +168 -0
- package/skills/ml-pipeline-workflow/SKILL.md +257 -0
- package/skills/mlops-engineer/SKILL.md +219 -0
- package/skills/mobile-developer/SKILL.md +205 -0
- package/skills/mobile-security-coder/SKILL.md +184 -0
- package/skills/modern-javascript-patterns/SKILL.md +35 -0
- package/skills/modern-javascript-patterns/resources/implementation-playbook.md +910 -0
- package/skills/monorepo-architect/SKILL.md +61 -0
- package/skills/monorepo-management/SKILL.md +35 -0
- package/skills/monorepo-management/resources/implementation-playbook.md +621 -0
- package/skills/mtls-configuration/SKILL.md +359 -0
- package/skills/multi-agent-patterns/SKILL.md +262 -0
- package/skills/multi-cloud-architecture/SKILL.md +189 -0
- package/skills/multi-platform-apps-multi-platform/SKILL.md +203 -0
- package/skills/n8n-code-python/SKILL.md +750 -0
- package/skills/n8n-mcp-tools-expert/SKILL.md +654 -0
- package/skills/n8n-node-configuration/SKILL.md +796 -0
- package/skills/nanobanana-ppt-skills/SKILL.md +22 -0
- package/skills/network-engineer/SKILL.md +169 -0
- package/skills/nextjs-app-router-patterns/SKILL.md +33 -0
- package/skills/nextjs-app-router-patterns/resources/implementation-playbook.md +543 -0
- package/skills/nft-standards/SKILL.md +395 -0
- package/skills/nodejs-backend-patterns/SKILL.md +35 -0
- package/skills/nodejs-backend-patterns/resources/implementation-playbook.md +1019 -0
- package/skills/notebooklm/AUTHENTICATION.md +0 -0
- package/skills/notebooklm/CHANGELOG.md +0 -0
- package/skills/notebooklm/LICENSE +0 -0
- package/skills/notebooklm/README.md +0 -0
- package/skills/notebooklm/SKILL.md +0 -0
- package/skills/notebooklm/images/example_notebookchat.png +0 -0
- package/skills/notebooklm/references/api_reference.md +0 -0
- package/skills/notebooklm/references/troubleshooting.md +0 -0
- package/skills/notebooklm/references/usage_patterns.md +0 -0
- package/skills/notebooklm/requirements.txt +0 -0
- package/skills/notebooklm/scripts/__init__.py +0 -0
- package/skills/notebooklm/scripts/ask_question.py +0 -0
- package/skills/notebooklm/scripts/auth_manager.py +0 -0
- package/skills/notebooklm/scripts/browser_session.py +0 -0
- package/skills/notebooklm/scripts/browser_utils.py +0 -0
- package/skills/notebooklm/scripts/cleanup_manager.py +0 -0
- package/skills/notebooklm/scripts/config.py +0 -0
- package/skills/notebooklm/scripts/notebook_manager.py +0 -0
- package/skills/notebooklm/scripts/run.py +0 -0
- package/skills/notebooklm/scripts/setup_environment.py +0 -0
- package/skills/notebooklm-skill/AUTHENTICATION.md +0 -0
- package/skills/notebooklm-skill/SKILL.md +0 -0
- package/skills/notebooklm-skill/references/api_reference.md +0 -0
- package/skills/notebooklm-skill/references/troubleshooting.md +0 -0
- package/skills/notebooklm-skill/references/usage_patterns.md +0 -0
- package/skills/notebooklm-skill/scripts/__init__.py +0 -0
- package/skills/notebooklm-skill/scripts/ask_question.py +0 -0
- package/skills/notebooklm-skill/scripts/auth_manager.py +0 -0
- package/skills/notebooklm-skill/scripts/browser_session.py +0 -0
- package/skills/notebooklm-skill/scripts/browser_utils.py +0 -0
- package/skills/notebooklm-skill/scripts/cleanup_manager.py +0 -0
- package/skills/notebooklm-skill/scripts/config.py +0 -0
- package/skills/notebooklm-skill/scripts/notebook_manager.py +0 -0
- package/skills/notebooklm-skill/scripts/run.py +0 -0
- package/skills/notebooklm-skill/scripts/setup_environment.py +0 -0
- package/skills/nx-workspace-patterns/SKILL.md +464 -0
- package/skills/observability-engineer/SKILL.md +237 -0
- package/skills/observability-monitoring-monitor-setup/SKILL.md +48 -0
- package/skills/observability-monitoring-monitor-setup/resources/implementation-playbook.md +505 -0
- package/skills/observability-monitoring-slo-implement/SKILL.md +43 -0
- package/skills/observability-monitoring-slo-implement/resources/implementation-playbook.md +1077 -0
- package/skills/observe-whatsapp/SKILL.md +109 -0
- package/skills/on-call-handoff-patterns/SKILL.md +453 -0
- package/skills/openapi-spec-generation/SKILL.md +33 -0
- package/skills/openapi-spec-generation/resources/implementation-playbook.md +1027 -0
- package/skills/payment-integration/SKILL.md +69 -110
- package/skills/paypal-integration/SKILL.md +479 -0
- package/skills/pci-compliance/SKILL.md +478 -0
- package/skills/pdf/LICENSE.txt +30 -0
- package/skills/pdf/SKILL.md +196 -6
- package/skills/pdf/forms.md +205 -0
- package/skills/pdf/reference.md +612 -0
- package/skills/pdf/scripts/check_bounding_boxes.py +70 -0
- package/skills/pdf/scripts/check_bounding_boxes_test.py +226 -0
- package/skills/pdf/scripts/check_fillable_fields.py +12 -0
- package/skills/pdf/scripts/convert_pdf_to_images.py +35 -0
- package/skills/pdf/scripts/create_validation_image.py +41 -0
- package/skills/pdf/scripts/extract_form_field_info.py +152 -0
- package/skills/pdf/scripts/fill_fillable_fields.py +114 -0
- package/skills/pdf/scripts/fill_pdf_form_with_annotations.py +108 -0
- package/skills/performance-engineer/SKILL.md +180 -0
- package/skills/performance-testing-review-ai-review/SKILL.md +450 -0
- package/skills/performance-testing-review-multi-agent-review/SKILL.md +216 -0
- package/skills/php-pro/SKILL.md +46 -78
- package/skills/playwright-skill/run.js +0 -0
- package/skills/podcast-generation/SKILL.md +0 -2
- package/skills/posix-shell-pro/SKILL.md +304 -0
- package/skills/postgresql/SKILL.md +230 -0
- package/skills/postmortem-writing/SKILL.md +386 -0
- package/skills/pptx/LICENSE.txt +30 -0
- package/skills/pptx/SKILL.md +456 -86
- package/skills/pptx/html2pptx.md +625 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -0
- package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -0
- package/skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -0
- package/skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -0
- package/skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -0
- package/skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -0
- package/skills/pptx/ooxml/schemas/mce/mc.xsd +75 -0
- package/skills/pptx/ooxml/schemas/microsoft/wml-2010.xsd +560 -0
- package/skills/pptx/ooxml/schemas/microsoft/wml-2012.xsd +67 -0
- package/skills/pptx/ooxml/schemas/microsoft/wml-2018.xsd +14 -0
- package/skills/pptx/ooxml/schemas/microsoft/wml-cex-2018.xsd +20 -0
- package/skills/pptx/ooxml/schemas/microsoft/wml-cid-2016.xsd +13 -0
- package/skills/pptx/ooxml/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -0
- package/skills/pptx/ooxml/schemas/microsoft/wml-symex-2015.xsd +8 -0
- package/skills/pptx/ooxml/scripts/pack.py +159 -0
- package/skills/pptx/ooxml/scripts/unpack.py +29 -0
- package/skills/pptx/ooxml/scripts/validate.py +69 -0
- package/skills/pptx/ooxml/scripts/validation/__init__.py +15 -0
- package/skills/pptx/ooxml/scripts/validation/base.py +951 -0
- package/skills/pptx/ooxml/scripts/validation/docx.py +274 -0
- package/skills/pptx/ooxml/scripts/validation/pptx.py +315 -0
- package/skills/pptx/ooxml/scripts/validation/redlining.py +279 -0
- package/skills/pptx/ooxml.md +427 -0
- package/skills/pptx/scripts/html2pptx.js +979 -0
- package/skills/pptx/scripts/inventory.py +1020 -0
- package/skills/pptx/scripts/rearrange.py +231 -0
- package/skills/pptx/scripts/replace.py +385 -0
- package/skills/pptx/scripts/thumbnail.py +450 -0
- package/skills/pptx-official/ooxml/scripts/pack.py +0 -0
- package/skills/pptx-official/ooxml/scripts/unpack.py +0 -0
- package/skills/pptx-official/ooxml/scripts/validate.py +0 -0
- package/skills/pptx-official/scripts/html2pptx.js +0 -0
- package/skills/pptx-official/scripts/inventory.py +0 -0
- package/skills/pptx-official/scripts/rearrange.py +0 -0
- package/skills/pptx-official/scripts/replace.py +0 -0
- package/skills/pptx-official/scripts/thumbnail.py +0 -0
- package/skills/projection-patterns/SKILL.md +33 -0
- package/skills/projection-patterns/resources/implementation-playbook.md +501 -0
- package/skills/prometheus-configuration/SKILL.md +404 -0
- package/skills/prompt-engineer/SKILL.md +243 -64
- package/skills/prompt-engineering-patterns/SKILL.md +213 -0
- package/skills/prompt-engineering-patterns/assets/few-shot-examples.json +106 -0
- package/skills/prompt-engineering-patterns/assets/prompt-template-library.md +246 -0
- package/skills/prompt-engineering-patterns/references/chain-of-thought.md +399 -0
- package/skills/prompt-engineering-patterns/references/few-shot-learning.md +369 -0
- package/skills/prompt-engineering-patterns/references/prompt-optimization.md +414 -0
- package/skills/prompt-engineering-patterns/references/prompt-templates.md +470 -0
- package/skills/prompt-engineering-patterns/references/system-prompts.md +189 -0
- package/skills/prompt-engineering-patterns/scripts/optimize-prompt.py +279 -0
- package/skills/protocol-reverse-engineering/SKILL.md +29 -0
- package/skills/protocol-reverse-engineering/resources/implementation-playbook.md +509 -0
- package/skills/pypict-skill/SKILL.md +22 -0
- package/skills/python-development-python-scaffold/SKILL.md +331 -0
- package/skills/python-packaging/SKILL.md +36 -0
- package/skills/python-packaging/resources/implementation-playbook.md +869 -0
- package/skills/python-performance-optimization/SKILL.md +36 -0
- package/skills/python-performance-optimization/resources/implementation-playbook.md +868 -0
- package/skills/python-pro/SKILL.md +155 -89
- package/skills/python-testing-patterns/SKILL.md +37 -0
- package/skills/python-testing-patterns/resources/implementation-playbook.md +906 -0
- package/skills/quant-analyst/SKILL.md +53 -0
- package/skills/radix-ui-design-system/SKILL.md +847 -0
- package/skills/radix-ui-design-system/examples/README.md +63 -0
- package/skills/radix-ui-design-system/examples/dialog-example.tsx +128 -0
- package/skills/radix-ui-design-system/examples/dropdown-example.tsx +162 -0
- package/skills/radix-ui-design-system/templates/component-template.tsx +148 -0
- package/skills/rag-implementation/SKILL.md +395 -37
- package/skills/react-modernization/SKILL.md +34 -0
- package/skills/react-modernization/resources/implementation-playbook.md +512 -0
- package/skills/react-native-architecture/SKILL.md +33 -0
- package/skills/react-native-architecture/resources/implementation-playbook.md +670 -0
- package/skills/react-state-management/SKILL.md +441 -0
- package/skills/readme/SKILL.md +775 -0
- package/skills/reference-builder/SKILL.md +188 -0
- package/skills/reverse-engineer/SKILL.md +173 -0
- package/skills/risk-manager/SKILL.md +61 -0
- package/skills/risk-metrics-calculation/SKILL.md +33 -0
- package/skills/risk-metrics-calculation/resources/implementation-playbook.md +554 -0
- package/skills/ruby-pro/SKILL.md +56 -0
- package/skills/rust-async-patterns/SKILL.md +33 -0
- package/skills/rust-async-patterns/resources/implementation-playbook.md +516 -0
- package/skills/rust-pro/SKILL.md +178 -0
- package/skills/saga-orchestration/SKILL.md +496 -0
- package/skills/sales-automator/SKILL.md +55 -0
- package/skills/sast-configuration/SKILL.md +212 -0
- package/skills/scala-pro/SKILL.md +82 -0
- package/skills/screen-reader-testing/SKILL.md +33 -0
- package/skills/screen-reader-testing/resources/implementation-playbook.md +544 -0
- package/skills/screenshots/SKILL.md +401 -0
- package/skills/search-specialist/SKILL.md +80 -0
- package/skills/secrets-management/SKILL.md +364 -0
- package/skills/security-auditor/SKILL.md +169 -0
- package/skills/security-bluebook-builder/SKILL.md +22 -0
- package/skills/security-compliance-compliance-check/SKILL.md +55 -0
- package/skills/security-compliance-compliance-check/resources/implementation-playbook.md +963 -0
- package/skills/security-requirement-extraction/SKILL.md +33 -0
- package/skills/security-requirement-extraction/resources/implementation-playbook.md +676 -0
- package/skills/security-scanning-security-dependencies/SKILL.md +43 -0
- package/skills/security-scanning-security-dependencies/resources/implementation-playbook.md +544 -0
- package/skills/security-scanning-security-hardening/SKILL.md +147 -0
- package/skills/security-scanning-security-sast/SKILL.md +495 -0
- package/skills/senior-architect/scripts/architecture_diagram_generator.py +0 -0
- package/skills/senior-architect/scripts/dependency_analyzer.py +0 -0
- package/skills/senior-architect/scripts/project_architect.py +0 -0
- package/skills/senior-backend/scripts/api_load_tester.py +0 -0
- package/skills/senior-backend/scripts/api_scaffolder.py +0 -0
- package/skills/senior-backend/scripts/database_migration_tool.py +0 -0
- package/skills/senior-computer-vision/scripts/dataset_pipeline_builder.py +0 -0
- package/skills/senior-computer-vision/scripts/inference_optimizer.py +0 -0
- package/skills/senior-computer-vision/scripts/vision_model_trainer.py +0 -0
- package/skills/senior-data-engineer/scripts/data_quality_validator.py +0 -0
- package/skills/senior-data-engineer/scripts/etl_performance_optimizer.py +0 -0
- package/skills/senior-data-engineer/scripts/pipeline_orchestrator.py +0 -0
- package/skills/senior-data-scientist/scripts/experiment_designer.py +0 -0
- package/skills/senior-data-scientist/scripts/feature_engineering_pipeline.py +0 -0
- package/skills/senior-data-scientist/scripts/model_evaluation_suite.py +0 -0
- package/skills/senior-devops/scripts/deployment_manager.py +0 -0
- package/skills/senior-devops/scripts/pipeline_generator.py +0 -0
- package/skills/senior-devops/scripts/terraform_scaffolder.py +0 -0
- package/skills/senior-frontend/scripts/bundle_analyzer.py +0 -0
- package/skills/senior-frontend/scripts/component_generator.py +0 -0
- package/skills/senior-frontend/scripts/frontend_scaffolder.py +0 -0
- package/skills/senior-fullstack/scripts/code_quality_analyzer.py +0 -0
- package/skills/senior-fullstack/scripts/fullstack_scaffolder.py +0 -0
- package/skills/senior-fullstack/scripts/project_scaffolder.py +0 -0
- package/skills/senior-ml-engineer/scripts/ml_monitoring_suite.py +0 -0
- package/skills/senior-ml-engineer/scripts/model_deployment_pipeline.py +0 -0
- package/skills/senior-ml-engineer/scripts/rag_system_builder.py +0 -0
- package/skills/senior-prompt-engineer/scripts/agent_orchestrator.py +0 -0
- package/skills/senior-prompt-engineer/scripts/prompt_optimizer.py +0 -0
- package/skills/senior-prompt-engineer/scripts/rag_evaluator.py +0 -0
- package/skills/senior-qa/scripts/coverage_analyzer.py +0 -0
- package/skills/senior-qa/scripts/e2e_test_scaffolder.py +0 -0
- package/skills/senior-qa/scripts/test_suite_generator.py +0 -0
- package/skills/senior-secops/scripts/compliance_checker.py +0 -0
- package/skills/senior-secops/scripts/security_scanner.py +0 -0
- package/skills/senior-secops/scripts/vulnerability_assessor.py +0 -0
- package/skills/senior-security/scripts/pentest_automator.py +0 -0
- package/skills/senior-security/scripts/security_auditor.py +0 -0
- package/skills/senior-security/scripts/threat_modeler.py +0 -0
- package/skills/seo-authority-builder/SKILL.md +136 -0
- package/skills/seo-cannibalization-detector/SKILL.md +123 -0
- package/skills/seo-content-auditor/SKILL.md +83 -0
- package/skills/seo-content-planner/SKILL.md +108 -0
- package/skills/seo-content-refresher/SKILL.md +118 -0
- package/skills/seo-content-writer/SKILL.md +96 -0
- package/skills/seo-keyword-strategist/SKILL.md +95 -0
- package/skills/seo-meta-optimizer/SKILL.md +92 -0
- package/skills/seo-snippet-hunter/SKILL.md +114 -0
- package/skills/seo-structure-architect/SKILL.md +108 -0
- package/skills/service-mesh-expert/SKILL.md +58 -0
- package/skills/service-mesh-observability/SKILL.md +395 -0
- package/skills/sharp-edges/SKILL.md +70 -0
- package/skills/shellcheck-configuration/SKILL.md +466 -0
- package/skills/similarity-search-patterns/SKILL.md +33 -0
- package/skills/similarity-search-patterns/resources/implementation-playbook.md +557 -0
- package/skills/skill-creator/scripts/init_skill.py +0 -0
- package/skills/skill-creator/scripts/package_skill.py +0 -0
- package/skills/skill-creator/scripts/quick_validate.py +0 -0
- package/skills/skill-rails-upgrade/SKILL.md +408 -0
- package/skills/skill-seekers/SKILL.md +22 -0
- package/skills/slack-gif-creator/core/easing.py +0 -0
- package/skills/slack-gif-creator/core/frame_composer.py +0 -0
- package/skills/slack-gif-creator/core/gif_builder.py +0 -0
- package/skills/slack-gif-creator/core/validators.py +0 -0
- package/skills/slo-implementation/SKILL.md +341 -0
- package/skills/solidity-security/SKILL.md +34 -0
- package/skills/solidity-security/resources/implementation-playbook.md +524 -0
- package/skills/spark-optimization/SKILL.md +427 -0
- package/skills/sql-optimization-patterns/SKILL.md +35 -0
- package/skills/sql-optimization-patterns/resources/implementation-playbook.md +504 -0
- package/skills/sql-pro/SKILL.md +170 -94
- package/skills/startup-analyst/SKILL.md +328 -0
- package/skills/startup-business-analyst-business-case/SKILL.md +487 -0
- package/skills/startup-business-analyst-financial-projections/SKILL.md +353 -0
- package/skills/startup-business-analyst-market-opportunity/SKILL.md +240 -0
- package/skills/startup-financial-modeling/SKILL.md +467 -0
- package/skills/startup-metrics-framework/SKILL.md +34 -0
- package/skills/startup-metrics-framework/resources/implementation-playbook.md +500 -0
- package/skills/stitch-ui-design/README.md +165 -0
- package/skills/stitch-ui-design/SKILL.md +378 -0
- package/skills/stitch-ui-design/references/advanced-techniques.md +541 -0
- package/skills/stitch-ui-design/references/prompt-examples.md +601 -0
- package/skills/stride-analysis-patterns/SKILL.md +33 -0
- package/skills/stride-analysis-patterns/resources/implementation-playbook.md +655 -0
- package/skills/stripe-integration/SKILL.md +429 -44
- package/skills/superpowers-lab/SKILL.md +22 -0
- package/skills/swiftui-expert-skill/SKILL.md +275 -0
- package/skills/systematic-debugging/find-polluter.sh +0 -0
- package/skills/systems-programming-rust-project/SKILL.md +440 -0
- package/skills/tailwind-design-system/SKILL.md +33 -0
- package/skills/tailwind-design-system/resources/implementation-playbook.md +665 -0
- package/skills/tdd-orchestrator/SKILL.md +205 -0
- package/skills/tdd-workflows-tdd-cycle/SKILL.md +221 -0
- package/skills/tdd-workflows-tdd-green/SKILL.md +73 -0
- package/skills/tdd-workflows-tdd-green/resources/implementation-playbook.md +870 -0
- package/skills/tdd-workflows-tdd-red/SKILL.md +164 -0
- package/skills/tdd-workflows-tdd-refactor/SKILL.md +187 -0
- package/skills/team-collaboration-issue/SKILL.md +37 -0
- package/skills/team-collaboration-issue/resources/implementation-playbook.md +640 -0
- package/skills/team-collaboration-standup-notes/SKILL.md +44 -0
- package/skills/team-collaboration-standup-notes/resources/implementation-playbook.md +768 -0
- package/skills/team-composition-analysis/SKILL.md +413 -0
- package/skills/temporal-python-pro/SKILL.md +370 -0
- package/skills/temporal-python-testing/SKILL.md +170 -0
- package/skills/temporal-python-testing/resources/integration-testing.md +455 -0
- package/skills/temporal-python-testing/resources/local-setup.md +553 -0
- package/skills/temporal-python-testing/resources/replay-testing.md +462 -0
- package/skills/temporal-python-testing/resources/unit-testing.md +328 -0
- package/skills/terraform-module-library/SKILL.md +261 -0
- package/skills/terraform-module-library/references/aws-modules.md +63 -0
- package/skills/terraform-skill/SKILL.md +517 -0
- package/skills/terraform-specialist/SKILL.md +166 -0
- package/skills/test-automator/SKILL.md +224 -0
- package/skills/threat-mitigation-mapping/SKILL.md +33 -0
- package/skills/threat-mitigation-mapping/resources/implementation-playbook.md +744 -0
- package/skills/threat-modeling-expert/SKILL.md +60 -0
- package/skills/threejs-skills/SKILL.md +22 -0
- package/skills/tool-design/SKILL.md +318 -0
- package/skills/track-management/SKILL.md +38 -0
- package/skills/track-management/resources/implementation-playbook.md +591 -0
- package/skills/turborepo-caching/SKILL.md +419 -0
- package/skills/tutorial-engineer/SKILL.md +139 -0
- package/skills/typescript-advanced-types/SKILL.md +35 -0
- package/skills/typescript-advanced-types/resources/implementation-playbook.md +716 -0
- package/skills/typescript-pro/SKILL.md +52 -91
- package/skills/ui-skills/SKILL.md +22 -0
- package/skills/ui-ux-designer/SKILL.md +209 -0
- package/skills/ui-ux-pro-max/SKILL.md +351 -351
- package/skills/ui-ux-pro-max/data/charts.csv +25 -25
- package/skills/ui-ux-pro-max/data/colors.csv +96 -96
- package/skills/ui-ux-pro-max/data/landing.csv +30 -30
- package/skills/ui-ux-pro-max/data/products.csv +96 -96
- package/skills/ui-ux-pro-max/data/prompts.csv +20 -20
- package/skills/ui-ux-pro-max/data/stacks/flutter.csv +53 -53
- package/skills/ui-ux-pro-max/data/stacks/html-tailwind.csv +56 -56
- package/skills/ui-ux-pro-max/data/stacks/nextjs.csv +53 -53
- package/skills/ui-ux-pro-max/data/stacks/react-native.csv +52 -52
- package/skills/ui-ux-pro-max/data/stacks/react.csv +54 -54
- package/skills/ui-ux-pro-max/data/stacks/svelte.csv +54 -54
- package/skills/ui-ux-pro-max/data/stacks/swiftui.csv +51 -51
- package/skills/ui-ux-pro-max/data/stacks/vue.csv +50 -50
- package/skills/ui-ux-pro-max/data/styles.csv +58 -58
- package/skills/ui-ux-pro-max/data/ux-guidelines.csv +99 -99
- package/skills/ui-ux-pro-max/scripts/search.py +76 -76
- package/skills/ui-visual-validator/SKILL.md +214 -0
- package/skills/unit-testing-test-generate/SKILL.md +319 -0
- package/skills/unity-developer/SKILL.md +230 -0
- package/skills/unity-ecs-patterns/SKILL.md +33 -0
- package/skills/unity-ecs-patterns/resources/implementation-playbook.md +625 -0
- package/skills/unreal-engine-cpp-pro/SKILL.md +114 -0
- package/skills/unreal-engine-cpp-pro/examples/ExampleActor.cpp +43 -0
- package/skills/unreal-engine-cpp-pro/examples/ExampleActor.h +57 -0
- package/skills/upgrading-expo/SKILL.md +108 -12
- package/skills/using-neon/SKILL.md +84 -0
- package/skills/uv-package-manager/SKILL.md +37 -0
- package/skills/uv-package-manager/resources/implementation-playbook.md +830 -0
- package/skills/varlock-claude-skill/SKILL.md +22 -0
- package/skills/vector-database-engineer/SKILL.md +60 -0
- package/skills/vector-index-tuning/SKILL.md +42 -0
- package/skills/vector-index-tuning/resources/implementation-playbook.md +507 -0
- package/skills/vercel-deploy-claimable/SKILL.md +120 -0
- package/skills/vercel-deployment/SKILL.md +10 -0
- package/skills/vexor/SKILL.md +22 -0
- package/skills/wcag-audit-patterns/SKILL.md +41 -0
- package/skills/wcag-audit-patterns/resources/implementation-playbook.md +541 -0
- package/skills/web-artifacts-builder/scripts/bundle-artifact.sh +0 -0
- package/skills/web-artifacts-builder/scripts/init-artifact.sh +0 -0
- package/skills/web3-testing/SKILL.md +427 -0
- package/skills/webapp-testing/scripts/with_server.py +0 -0
- package/skills/workflow-orchestration-patterns/SKILL.md +333 -0
- package/skills/workflow-patterns/SKILL.md +38 -0
- package/skills/workflow-patterns/resources/implementation-playbook.md +621 -0
- package/skills/writing-skills/SKILL.md +84 -696
- package/skills/writing-skills/examples.md +282 -0
- package/skills/writing-skills/gotchas.md +197 -0
- package/skills/writing-skills/references/anti-rationalization/README.md +255 -0
- package/skills/writing-skills/references/cso/README.md +268 -0
- package/skills/writing-skills/references/standards/README.md +152 -0
- package/skills/writing-skills/references/standards/metadata-standard.md +65 -0
- package/skills/writing-skills/references/templates/discipline.md +54 -0
- package/skills/writing-skills/references/templates/pattern.md +48 -0
- package/skills/writing-skills/references/templates/reference.md +35 -0
- package/skills/writing-skills/references/templates/technique.md +59 -0
- package/skills/writing-skills/references/templates/tier-3-platform.md +19 -0
- package/skills/writing-skills/references/testing/README.md +204 -0
- package/skills/writing-skills/references/tier-1-simple/README.md +75 -0
- package/skills/writing-skills/references/tier-2-expanded/README.md +69 -0
- package/skills/writing-skills/references/tier-3-platform/README.md +98 -0
- package/skills/writing-skills/render-graphs.js +0 -0
- package/skills/x-article-publisher-skill/SKILL.md +22 -0
- package/skills/xlsx/LICENSE.txt +30 -0
- package/skills/xlsx/SKILL.md +217 -28
- package/skills/xlsx/recalc.py +178 -0
|
@@ -0,0 +1,496 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: deployment-validation-config-validate
|
|
3
|
+
description: "You are a configuration management expert specializing in validating, testing, and ensuring the correctness of application configurations. Create comprehensive validation schemas, implement configurat"
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Configuration Validation
|
|
7
|
+
|
|
8
|
+
You are a configuration management expert specializing in validating, testing, and ensuring the correctness of application configurations. Create comprehensive validation schemas, implement configuration testing strategies, and ensure configurations are secure, consistent, and error-free across all environments.
|
|
9
|
+
|
|
10
|
+
## Use this skill when
|
|
11
|
+
|
|
12
|
+
- Working on configuration validation tasks or workflows
|
|
13
|
+
- Needing guidance, best practices, or checklists for configuration validation
|
|
14
|
+
|
|
15
|
+
## Do not use this skill when
|
|
16
|
+
|
|
17
|
+
- The task is unrelated to configuration validation
|
|
18
|
+
- You need a different domain or tool outside this scope
|
|
19
|
+
|
|
20
|
+
## Context
|
|
21
|
+
The user needs to validate configuration files, implement configuration schemas, ensure consistency across environments, and prevent configuration-related errors. Focus on creating robust validation rules, type safety, security checks, and automated validation processes.
|
|
22
|
+
|
|
23
|
+
## Requirements
|
|
24
|
+
$ARGUMENTS
|
|
25
|
+
|
|
26
|
+
## Instructions
|
|
27
|
+
|
|
28
|
+
### 1. Configuration Analysis
|
|
29
|
+
|
|
30
|
+
Analyze existing configuration structure and identify validation needs:
|
|
31
|
+
|
|
32
|
+
```python
|
|
33
|
+
import os
|
|
34
|
+
import yaml
|
|
35
|
+
import json
|
|
36
|
+
from pathlib import Path
|
|
37
|
+
from typing import Dict, List, Any
|
|
38
|
+
|
|
39
|
+
class ConfigurationAnalyzer:
|
|
40
|
+
def analyze_project(self, project_path: str) -> Dict[str, Any]:
|
|
41
|
+
analysis = {
|
|
42
|
+
'config_files': self._find_config_files(project_path),
|
|
43
|
+
'security_issues': self._check_security_issues(project_path),
|
|
44
|
+
'consistency_issues': self._check_consistency(project_path),
|
|
45
|
+
'recommendations': []
|
|
46
|
+
}
|
|
47
|
+
return analysis
|
|
48
|
+
|
|
49
|
+
def _find_config_files(self, project_path: str) -> List[Dict]:
|
|
50
|
+
config_patterns = [
|
|
51
|
+
'**/*.json', '**/*.yaml', '**/*.yml', '**/*.toml',
|
|
52
|
+
'**/*.ini', '**/*.env*', '**/config.js'
|
|
53
|
+
]
|
|
54
|
+
|
|
55
|
+
config_files = []
|
|
56
|
+
for pattern in config_patterns:
|
|
57
|
+
for file_path in Path(project_path).glob(pattern):
|
|
58
|
+
if not self._should_ignore(file_path):
|
|
59
|
+
config_files.append({
|
|
60
|
+
'path': str(file_path),
|
|
61
|
+
'type': self._detect_config_type(file_path),
|
|
62
|
+
'environment': self._detect_environment(file_path)
|
|
63
|
+
})
|
|
64
|
+
return config_files
|
|
65
|
+
|
|
66
|
+
def _check_security_issues(self, project_path: str) -> List[Dict]:
|
|
67
|
+
issues = []
|
|
68
|
+
secret_patterns = [
|
|
69
|
+
r'(api[_-]?key|apikey)',
|
|
70
|
+
r'(secret|password|passwd)',
|
|
71
|
+
r'(token|auth)',
|
|
72
|
+
r'(aws[_-]?access)'
|
|
73
|
+
]
|
|
74
|
+
|
|
75
|
+
for config_file in self._find_config_files(project_path):
|
|
76
|
+
content = Path(config_file['path']).read_text()
|
|
77
|
+
for pattern in secret_patterns:
|
|
78
|
+
if re.search(pattern, content, re.IGNORECASE):
|
|
79
|
+
if self._looks_like_real_secret(content, pattern):
|
|
80
|
+
issues.append({
|
|
81
|
+
'file': config_file['path'],
|
|
82
|
+
'type': 'potential_secret',
|
|
83
|
+
'severity': 'high'
|
|
84
|
+
})
|
|
85
|
+
return issues
|
|
86
|
+
```
|
|
87
|
+
|
|
88
|
+
### 2. Schema Validation
|
|
89
|
+
|
|
90
|
+
Implement configuration schema validation with JSON Schema:
|
|
91
|
+
|
|
92
|
+
```typescript
|
|
93
|
+
import Ajv from 'ajv';
|
|
94
|
+
import ajvFormats from 'ajv-formats';
|
|
95
|
+
import { JSONSchema7 } from 'json-schema';
|
|
96
|
+
|
|
97
|
+
interface ValidationResult {
|
|
98
|
+
valid: boolean;
|
|
99
|
+
errors?: Array<{
|
|
100
|
+
path: string;
|
|
101
|
+
message: string;
|
|
102
|
+
keyword: string;
|
|
103
|
+
}>;
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
export class ConfigValidator {
|
|
107
|
+
private ajv: Ajv;
|
|
108
|
+
|
|
109
|
+
constructor() {
|
|
110
|
+
this.ajv = new Ajv({
|
|
111
|
+
allErrors: true,
|
|
112
|
+
strict: false,
|
|
113
|
+
coerceTypes: true
|
|
114
|
+
});
|
|
115
|
+
ajvFormats(this.ajv);
|
|
116
|
+
this.addCustomFormats();
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
private addCustomFormats() {
|
|
120
|
+
this.ajv.addFormat('url-https', {
|
|
121
|
+
type: 'string',
|
|
122
|
+
validate: (data: string) => {
|
|
123
|
+
try {
|
|
124
|
+
return new URL(data).protocol === 'https:';
|
|
125
|
+
} catch { return false; }
|
|
126
|
+
}
|
|
127
|
+
});
|
|
128
|
+
|
|
129
|
+
this.ajv.addFormat('port', {
|
|
130
|
+
type: 'number',
|
|
131
|
+
validate: (data: number) => data >= 1 && data <= 65535
|
|
132
|
+
});
|
|
133
|
+
|
|
134
|
+
this.ajv.addFormat('duration', {
|
|
135
|
+
type: 'string',
|
|
136
|
+
validate: /^\d+[smhd]$/
|
|
137
|
+
});
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
validate(configData: any, schemaName: string): ValidationResult {
|
|
141
|
+
const validate = this.ajv.getSchema(schemaName);
|
|
142
|
+
if (!validate) throw new Error(`Schema '${schemaName}' not found`);
|
|
143
|
+
|
|
144
|
+
const valid = validate(configData);
|
|
145
|
+
|
|
146
|
+
if (!valid && validate.errors) {
|
|
147
|
+
return {
|
|
148
|
+
valid: false,
|
|
149
|
+
errors: validate.errors.map(error => ({
|
|
150
|
+
path: error.instancePath || '/',
|
|
151
|
+
message: error.message || 'Validation error',
|
|
152
|
+
keyword: error.keyword
|
|
153
|
+
}))
|
|
154
|
+
};
|
|
155
|
+
}
|
|
156
|
+
return { valid: true };
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
// Example schema
|
|
161
|
+
export const schemas = {
|
|
162
|
+
database: {
|
|
163
|
+
type: 'object',
|
|
164
|
+
properties: {
|
|
165
|
+
host: { type: 'string', format: 'hostname' },
|
|
166
|
+
port: { type: 'integer', format: 'port' },
|
|
167
|
+
database: { type: 'string', minLength: 1 },
|
|
168
|
+
user: { type: 'string', minLength: 1 },
|
|
169
|
+
password: { type: 'string', minLength: 8 },
|
|
170
|
+
ssl: {
|
|
171
|
+
type: 'object',
|
|
172
|
+
properties: {
|
|
173
|
+
enabled: { type: 'boolean' }
|
|
174
|
+
},
|
|
175
|
+
required: ['enabled']
|
|
176
|
+
}
|
|
177
|
+
},
|
|
178
|
+
required: ['host', 'port', 'database', 'user', 'password']
|
|
179
|
+
}
|
|
180
|
+
};
|
|
181
|
+
```
|
|
182
|
+
|
|
183
|
+
### 3. Environment-Specific Validation
|
|
184
|
+
|
|
185
|
+
```python
|
|
186
|
+
from typing import Dict, List, Any
|
|
187
|
+
|
|
188
|
+
class EnvironmentValidator:
|
|
189
|
+
def __init__(self):
|
|
190
|
+
self.environments = ['development', 'staging', 'production']
|
|
191
|
+
self.environment_rules = {
|
|
192
|
+
'development': {
|
|
193
|
+
'allow_debug': True,
|
|
194
|
+
'require_https': False,
|
|
195
|
+
'min_password_length': 8
|
|
196
|
+
},
|
|
197
|
+
'production': {
|
|
198
|
+
'allow_debug': False,
|
|
199
|
+
'require_https': True,
|
|
200
|
+
'min_password_length': 16,
|
|
201
|
+
'require_encryption': True
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
|
|
205
|
+
def validate_config(self, config: Dict, environment: str) -> List[Dict]:
|
|
206
|
+
if environment not in self.environment_rules:
|
|
207
|
+
raise ValueError(f"Unknown environment: {environment}")
|
|
208
|
+
|
|
209
|
+
rules = self.environment_rules[environment]
|
|
210
|
+
violations = []
|
|
211
|
+
|
|
212
|
+
if not rules['allow_debug'] and config.get('debug', False):
|
|
213
|
+
violations.append({
|
|
214
|
+
'rule': 'no_debug_in_production',
|
|
215
|
+
'message': 'Debug mode not allowed in production',
|
|
216
|
+
'severity': 'critical'
|
|
217
|
+
})
|
|
218
|
+
|
|
219
|
+
if rules['require_https']:
|
|
220
|
+
urls = self._extract_urls(config)
|
|
221
|
+
for url_path, url in urls:
|
|
222
|
+
if url.startswith('http://') and 'localhost' not in url:
|
|
223
|
+
violations.append({
|
|
224
|
+
'rule': 'require_https',
|
|
225
|
+
'message': f'HTTPS required for {url_path}',
|
|
226
|
+
'severity': 'high'
|
|
227
|
+
})
|
|
228
|
+
|
|
229
|
+
return violations
|
|
230
|
+
```
|
|
231
|
+
|
|
232
|
+
### 4. Configuration Testing
|
|
233
|
+
|
|
234
|
+
```typescript
|
|
235
|
+
import { describe, it, expect } from '@jest/globals';
|
|
236
|
+
import { ConfigValidator } from './config-validator';
|
|
237
|
+
|
|
238
|
+
describe('Configuration Validation', () => {
|
|
239
|
+
let validator: ConfigValidator;
|
|
240
|
+
|
|
241
|
+
beforeEach(() => {
|
|
242
|
+
validator = new ConfigValidator();
|
|
243
|
+
});
|
|
244
|
+
|
|
245
|
+
it('should validate database config', () => {
|
|
246
|
+
const config = {
|
|
247
|
+
host: 'localhost',
|
|
248
|
+
port: 5432,
|
|
249
|
+
database: 'myapp',
|
|
250
|
+
user: 'dbuser',
|
|
251
|
+
password: 'securepass123'
|
|
252
|
+
};
|
|
253
|
+
|
|
254
|
+
const result = validator.validate(config, 'database');
|
|
255
|
+
expect(result.valid).toBe(true);
|
|
256
|
+
});
|
|
257
|
+
|
|
258
|
+
it('should reject invalid port', () => {
|
|
259
|
+
const config = {
|
|
260
|
+
host: 'localhost',
|
|
261
|
+
port: 70000,
|
|
262
|
+
database: 'myapp',
|
|
263
|
+
user: 'dbuser',
|
|
264
|
+
password: 'securepass123'
|
|
265
|
+
};
|
|
266
|
+
|
|
267
|
+
const result = validator.validate(config, 'database');
|
|
268
|
+
expect(result.valid).toBe(false);
|
|
269
|
+
});
|
|
270
|
+
});
|
|
271
|
+
```
|
|
272
|
+
|
|
273
|
+
### 5. Runtime Validation
|
|
274
|
+
|
|
275
|
+
```typescript
|
|
276
|
+
import { EventEmitter } from 'events';
|
|
277
|
+
import * as chokidar from 'chokidar';
|
|
278
|
+
|
|
279
|
+
export class RuntimeConfigValidator extends EventEmitter {
|
|
280
|
+
private validator: ConfigValidator;
|
|
281
|
+
private currentConfig: any;
|
|
282
|
+
|
|
283
|
+
async initialize(configPath: string): Promise<void> {
|
|
284
|
+
this.currentConfig = await this.loadAndValidate(configPath);
|
|
285
|
+
this.watchConfig(configPath);
|
|
286
|
+
}
|
|
287
|
+
|
|
288
|
+
private async loadAndValidate(configPath: string): Promise<any> {
|
|
289
|
+
const config = await this.loadConfig(configPath);
|
|
290
|
+
|
|
291
|
+
const validationResult = this.validator.validate(
|
|
292
|
+
config,
|
|
293
|
+
this.detectEnvironment()
|
|
294
|
+
);
|
|
295
|
+
|
|
296
|
+
if (!validationResult.valid) {
|
|
297
|
+
this.emit('validation:error', {
|
|
298
|
+
path: configPath,
|
|
299
|
+
errors: validationResult.errors
|
|
300
|
+
});
|
|
301
|
+
|
|
302
|
+
if (!this.isDevelopment()) {
|
|
303
|
+
throw new Error('Configuration validation failed');
|
|
304
|
+
}
|
|
305
|
+
}
|
|
306
|
+
|
|
307
|
+
return config;
|
|
308
|
+
}
|
|
309
|
+
|
|
310
|
+
private watchConfig(configPath: string): void {
|
|
311
|
+
const watcher = chokidar.watch(configPath, {
|
|
312
|
+
persistent: true,
|
|
313
|
+
ignoreInitial: true
|
|
314
|
+
});
|
|
315
|
+
|
|
316
|
+
watcher.on('change', async () => {
|
|
317
|
+
try {
|
|
318
|
+
const newConfig = await this.loadAndValidate(configPath);
|
|
319
|
+
|
|
320
|
+
if (JSON.stringify(newConfig) !== JSON.stringify(this.currentConfig)) {
|
|
321
|
+
this.emit('config:changed', {
|
|
322
|
+
oldConfig: this.currentConfig,
|
|
323
|
+
newConfig
|
|
324
|
+
});
|
|
325
|
+
this.currentConfig = newConfig;
|
|
326
|
+
}
|
|
327
|
+
} catch (error) {
|
|
328
|
+
this.emit('config:error', { error });
|
|
329
|
+
}
|
|
330
|
+
});
|
|
331
|
+
}
|
|
332
|
+
}
|
|
333
|
+
```
|
|
334
|
+
|
|
335
|
+
### 6. Configuration Migration
|
|
336
|
+
|
|
337
|
+
```python
|
|
338
|
+
from typing import Dict
|
|
339
|
+
from abc import ABC, abstractmethod
|
|
340
|
+
import semver
|
|
341
|
+
|
|
342
|
+
class ConfigMigration(ABC):
|
|
343
|
+
@property
|
|
344
|
+
@abstractmethod
|
|
345
|
+
def version(self) -> str:
|
|
346
|
+
pass
|
|
347
|
+
|
|
348
|
+
@abstractmethod
|
|
349
|
+
def up(self, config: Dict) -> Dict:
|
|
350
|
+
pass
|
|
351
|
+
|
|
352
|
+
@abstractmethod
|
|
353
|
+
def down(self, config: Dict) -> Dict:
|
|
354
|
+
pass
|
|
355
|
+
|
|
356
|
+
class ConfigMigrator:
|
|
357
|
+
def __init__(self):
|
|
358
|
+
self.migrations: List[ConfigMigration] = []
|
|
359
|
+
|
|
360
|
+
def migrate(self, config: Dict, target_version: str) -> Dict:
|
|
361
|
+
current_version = config.get('_version', '0.0.0')
|
|
362
|
+
|
|
363
|
+
if semver.compare(current_version, target_version) == 0:
|
|
364
|
+
return config
|
|
365
|
+
|
|
366
|
+
result = config.copy()
|
|
367
|
+
for migration in self.migrations:
|
|
368
|
+
if (semver.compare(migration.version, current_version) > 0 and
|
|
369
|
+
semver.compare(migration.version, target_version) <= 0):
|
|
370
|
+
result = migration.up(result)
|
|
371
|
+
result['_version'] = migration.version
|
|
372
|
+
|
|
373
|
+
return result
|
|
374
|
+
```
|
|
375
|
+
|
|
376
|
+
### 7. Secure Configuration
|
|
377
|
+
|
|
378
|
+
```typescript
|
|
379
|
+
import * as crypto from 'crypto';
|
|
380
|
+
|
|
381
|
+
interface EncryptedValue {
|
|
382
|
+
encrypted: true;
|
|
383
|
+
value: string;
|
|
384
|
+
algorithm: string;
|
|
385
|
+
iv: string;
|
|
386
|
+
authTag?: string;
|
|
387
|
+
}
|
|
388
|
+
|
|
389
|
+
export class SecureConfigManager {
|
|
390
|
+
private encryptionKey: Buffer;
|
|
391
|
+
|
|
392
|
+
constructor(masterKey: string) {
|
|
393
|
+
this.encryptionKey = crypto.pbkdf2Sync(masterKey, 'config-salt', 100000, 32, 'sha256');
|
|
394
|
+
}
|
|
395
|
+
|
|
396
|
+
encrypt(value: any): EncryptedValue {
|
|
397
|
+
const algorithm = 'aes-256-gcm';
|
|
398
|
+
const iv = crypto.randomBytes(16);
|
|
399
|
+
const cipher = crypto.createCipheriv(algorithm, this.encryptionKey, iv);
|
|
400
|
+
|
|
401
|
+
let encrypted = cipher.update(JSON.stringify(value), 'utf8', 'hex');
|
|
402
|
+
encrypted += cipher.final('hex');
|
|
403
|
+
|
|
404
|
+
return {
|
|
405
|
+
encrypted: true,
|
|
406
|
+
value: encrypted,
|
|
407
|
+
algorithm,
|
|
408
|
+
iv: iv.toString('hex'),
|
|
409
|
+
authTag: cipher.getAuthTag().toString('hex')
|
|
410
|
+
};
|
|
411
|
+
}
|
|
412
|
+
|
|
413
|
+
decrypt(encryptedValue: EncryptedValue): any {
|
|
414
|
+
const decipher = crypto.createDecipheriv(
|
|
415
|
+
encryptedValue.algorithm,
|
|
416
|
+
this.encryptionKey,
|
|
417
|
+
Buffer.from(encryptedValue.iv, 'hex')
|
|
418
|
+
);
|
|
419
|
+
|
|
420
|
+
if (encryptedValue.authTag) {
|
|
421
|
+
decipher.setAuthTag(Buffer.from(encryptedValue.authTag, 'hex'));
|
|
422
|
+
}
|
|
423
|
+
|
|
424
|
+
let decrypted = decipher.update(encryptedValue.value, 'hex', 'utf8');
|
|
425
|
+
decrypted += decipher.final('utf8');
|
|
426
|
+
|
|
427
|
+
return JSON.parse(decrypted);
|
|
428
|
+
}
|
|
429
|
+
|
|
430
|
+
async processConfig(config: any): Promise<any> {
|
|
431
|
+
const processed = {};
|
|
432
|
+
|
|
433
|
+
for (const [key, value] of Object.entries(config)) {
|
|
434
|
+
if (this.isEncryptedValue(value)) {
|
|
435
|
+
processed[key] = this.decrypt(value as EncryptedValue);
|
|
436
|
+
} else if (typeof value === 'object' && value !== null) {
|
|
437
|
+
processed[key] = await this.processConfig(value);
|
|
438
|
+
} else {
|
|
439
|
+
processed[key] = value;
|
|
440
|
+
}
|
|
441
|
+
}
|
|
442
|
+
|
|
443
|
+
return processed;
|
|
444
|
+
}
|
|
445
|
+
}
|
|
446
|
+
```
|
|
447
|
+
|
|
448
|
+
### 8. Documentation Generation
|
|
449
|
+
|
|
450
|
+
```python
|
|
451
|
+
from typing import Dict, List
|
|
452
|
+
import yaml
|
|
453
|
+
|
|
454
|
+
class ConfigDocGenerator:
|
|
455
|
+
def generate_docs(self, schema: Dict, examples: Dict) -> str:
|
|
456
|
+
docs = ["# Configuration Reference\n"]
|
|
457
|
+
|
|
458
|
+
docs.append("## Configuration Options\n")
|
|
459
|
+
sections = self._generate_sections(schema.get('properties', {}), examples)
|
|
460
|
+
docs.extend(sections)
|
|
461
|
+
|
|
462
|
+
return '\n'.join(docs)
|
|
463
|
+
|
|
464
|
+
def _generate_sections(self, properties: Dict, examples: Dict, level: int = 3) -> List[str]:
|
|
465
|
+
sections = []
|
|
466
|
+
|
|
467
|
+
for prop_name, prop_schema in properties.items():
|
|
468
|
+
sections.append(f"{'#' * level} {prop_name}\n")
|
|
469
|
+
|
|
470
|
+
if 'description' in prop_schema:
|
|
471
|
+
sections.append(f"{prop_schema['description']}\n")
|
|
472
|
+
|
|
473
|
+
sections.append(f"**Type:** `{prop_schema.get('type', 'any')}`\n")
|
|
474
|
+
|
|
475
|
+
if 'default' in prop_schema:
|
|
476
|
+
sections.append(f"**Default:** `{prop_schema['default']}`\n")
|
|
477
|
+
|
|
478
|
+
if prop_name in examples:
|
|
479
|
+
sections.append("**Example:**\n```yaml")
|
|
480
|
+
sections.append(yaml.dump({prop_name: examples[prop_name]}))
|
|
481
|
+
sections.append("```\n")
|
|
482
|
+
|
|
483
|
+
return sections
|
|
484
|
+
```
|
|
485
|
+
|
|
486
|
+
## Output Format
|
|
487
|
+
|
|
488
|
+
1. **Configuration Analysis**: Current configuration assessment
|
|
489
|
+
2. **Validation Schemas**: JSON Schema definitions
|
|
490
|
+
3. **Environment Rules**: Environment-specific validation
|
|
491
|
+
4. **Test Suite**: Configuration tests
|
|
492
|
+
5. **Migration Scripts**: Version migrations
|
|
493
|
+
6. **Security Report**: Issues and recommendations
|
|
494
|
+
7. **Documentation**: Auto-generated reference
|
|
495
|
+
|
|
496
|
+
Focus on preventing configuration errors, ensuring consistency, and maintaining security best practices.
|
|
@@ -0,0 +1,178 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: design-md
|
|
3
|
+
description: "Analyze Stitch projects and synthesize a semantic design system into DESIGN.md files"
|
|
4
|
+
source: "https://github.com/google-labs-code/stitch-skills/tree/main/skills/design-md"
|
|
5
|
+
risk: safe
|
|
6
|
+
---
|
|
7
|
+
|
|
8
|
+
# Stitch DESIGN.md Skill
|
|
9
|
+
|
|
10
|
+
You are an expert Design Systems Lead. Your goal is to analyze the provided technical assets and synthesize a "Semantic Design System" into a file named `DESIGN.md`.
|
|
11
|
+
|
|
12
|
+
## When to Use This Skill
|
|
13
|
+
|
|
14
|
+
Use this skill when:
|
|
15
|
+
- Analyzing Stitch projects
|
|
16
|
+
- Creating DESIGN.md files
|
|
17
|
+
- Synthesizing semantic design systems
|
|
18
|
+
- Working with Stitch design language
|
|
19
|
+
- Generating design documentation for Stitch projects
|
|
20
|
+
|
|
21
|
+
## Overview
|
|
22
|
+
|
|
23
|
+
This skill helps you create `DESIGN.md` files that serve as the "source of truth" for prompting Stitch to generate new screens that align perfectly with existing design language. Stitch interprets design through "Visual Descriptions" supported by specific color values.
|
|
24
|
+
|
|
25
|
+
## Prerequisites
|
|
26
|
+
|
|
27
|
+
- Access to the Stitch MCP Server
|
|
28
|
+
- A Stitch project with at least one designed screen
|
|
29
|
+
- Access to the Stitch Effective Prompting Guide: https://stitch.withgoogle.com/docs/learn/prompting/
|
|
30
|
+
|
|
31
|
+
## The Goal
|
|
32
|
+
|
|
33
|
+
The `DESIGN.md` file will serve as the "source of truth" for prompting Stitch to generate new screens that align perfectly with the existing design language. Stitch interprets design through "Visual Descriptions" supported by specific color values.
|
|
34
|
+
|
|
35
|
+
## Retrieval and Networking
|
|
36
|
+
|
|
37
|
+
To analyze a Stitch project, you must retrieve screen metadata and design assets using the Stitch MCP Server tools:
|
|
38
|
+
|
|
39
|
+
1. **Namespace discovery**: Run `list_tools` to find the Stitch MCP prefix. Use this prefix (e.g., `mcp_stitch:`) for all subsequent calls.
|
|
40
|
+
|
|
41
|
+
2. **Project lookup** (if Project ID is not provided):
|
|
42
|
+
- Call `[prefix]:list_projects` with `filter: "view=owned"` to retrieve all user projects
|
|
43
|
+
- Identify the target project by title or URL pattern
|
|
44
|
+
- Extract the Project ID from the `name` field (e.g., `projects/13534454087919359824`)
|
|
45
|
+
|
|
46
|
+
3. **Screen lookup** (if Screen ID is not provided):
|
|
47
|
+
- Call `[prefix]:list_screens` with the `projectId` (just the numeric ID, not the full path)
|
|
48
|
+
- Review screen titles to identify the target screen (e.g., "Home", "Landing Page")
|
|
49
|
+
- Extract the Screen ID from the screen's `name` field
|
|
50
|
+
|
|
51
|
+
4. **Metadata fetch**:
|
|
52
|
+
- Call `[prefix]:get_screen` with both `projectId` and `screenId` (both as numeric IDs only)
|
|
53
|
+
- This returns the complete screen object including:
|
|
54
|
+
- `screenshot.downloadUrl` - Visual reference of the design
|
|
55
|
+
- `htmlCode.downloadUrl` - Full HTML/CSS source code
|
|
56
|
+
- `width`, `height`, `deviceType` - Screen dimensions and target platform
|
|
57
|
+
- Project metadata including `designTheme` with color and style information
|
|
58
|
+
|
|
59
|
+
5. **Asset download**:
|
|
60
|
+
- Use `web_fetch` or `read_url_content` to download the HTML code from `htmlCode.downloadUrl`
|
|
61
|
+
- Optionally download the screenshot from `screenshot.downloadUrl` for visual reference
|
|
62
|
+
- Parse the HTML to extract Tailwind classes, custom CSS, and component patterns
|
|
63
|
+
|
|
64
|
+
6. **Project metadata extraction**:
|
|
65
|
+
- Call `[prefix]:get_project` with the project `name` (full path: `projects/{id}`) to get:
|
|
66
|
+
- `designTheme` object with color mode, fonts, roundness, custom colors
|
|
67
|
+
- Project-level design guidelines and descriptions
|
|
68
|
+
- Device type preferences and layout principles
|
|
69
|
+
|
|
70
|
+
## Analysis & Synthesis Instructions
|
|
71
|
+
|
|
72
|
+
### 1. Extract Project Identity (JSON)
|
|
73
|
+
- Locate the Project Title
|
|
74
|
+
- Locate the specific Project ID (e.g., from the `name` field in the JSON)
|
|
75
|
+
|
|
76
|
+
### 2. Define the Atmosphere (Image/HTML)
|
|
77
|
+
Evaluate the screenshot and HTML structure to capture the overall "vibe." Use evocative adjectives to describe the mood (e.g., "Airy," "Dense," "Minimalist," "Utilitarian").
|
|
78
|
+
|
|
79
|
+
### 3. Map the Color Palette (Tailwind Config/JSON)
|
|
80
|
+
Identify the key colors in the system. For each color, provide:
|
|
81
|
+
- A descriptive, natural language name that conveys its character (e.g., "Deep Muted Teal-Navy")
|
|
82
|
+
- The specific hex code in parentheses for precision (e.g., "#294056")
|
|
83
|
+
- Its specific functional role (e.g., "Used for primary actions")
|
|
84
|
+
|
|
85
|
+
### 4. Translate Geometry & Shape (CSS/Tailwind)
|
|
86
|
+
Convert technical `border-radius` and layout values into physical descriptions:
|
|
87
|
+
- Describe `rounded-full` as "Pill-shaped"
|
|
88
|
+
- Describe `rounded-lg` as "Subtly rounded corners"
|
|
89
|
+
- Describe `rounded-none` as "Sharp, squared-off edges"
|
|
90
|
+
|
|
91
|
+
### 5. Describe Depth & Elevation
|
|
92
|
+
Explain how the UI handles layers. Describe the presence and quality of shadows (e.g., "Flat," "Whisper-soft diffused shadows," or "Heavy, high-contrast drop shadows").
|
|
93
|
+
|
|
94
|
+
## Output Guidelines
|
|
95
|
+
|
|
96
|
+
- **Language:** Use descriptive design terminology and natural language exclusively
|
|
97
|
+
- **Format:** Generate a clean Markdown file following the structure below
|
|
98
|
+
- **Precision:** Include exact hex codes for colors while using descriptive names
|
|
99
|
+
- **Context:** Explain the "why" behind design decisions, not just the "what"
|
|
100
|
+
|
|
101
|
+
## Output Format (DESIGN.md Structure)
|
|
102
|
+
|
|
103
|
+
```markdown
|
|
104
|
+
# Design System: [Project Title]
|
|
105
|
+
**Project ID:** [Insert Project ID Here]
|
|
106
|
+
|
|
107
|
+
## 1. Visual Theme & Atmosphere
|
|
108
|
+
(Description of the mood, density, and aesthetic philosophy.)
|
|
109
|
+
|
|
110
|
+
## 2. Color Palette & Roles
|
|
111
|
+
(List colors by Descriptive Name + Hex Code + Functional Role.)
|
|
112
|
+
|
|
113
|
+
## 3. Typography Rules
|
|
114
|
+
(Description of font family, weight usage for headers vs. body, and letter-spacing character.)
|
|
115
|
+
|
|
116
|
+
## 4. Component Stylings
|
|
117
|
+
* **Buttons:** (Shape description, color assignment, behavior).
|
|
118
|
+
* **Cards/Containers:** (Corner roundness description, background color, shadow depth).
|
|
119
|
+
* **Inputs/Forms:** (Stroke style, background).
|
|
120
|
+
|
|
121
|
+
## 5. Layout Principles
|
|
122
|
+
(Description of whitespace strategy, margins, and grid alignment.)
|
|
123
|
+
```
|
|
124
|
+
|
|
125
|
+
## Usage Example
|
|
126
|
+
|
|
127
|
+
To use this skill for the Furniture Collection project:
|
|
128
|
+
|
|
129
|
+
1. **Retrieve project information:**
|
|
130
|
+
```
|
|
131
|
+
Use the Stitch MCP Server to get the Furniture Collection project
|
|
132
|
+
```
|
|
133
|
+
|
|
134
|
+
2. **Get the Home page screen details:**
|
|
135
|
+
```
|
|
136
|
+
Retrieve the Home page screen's code, image, and screen object information
|
|
137
|
+
```
|
|
138
|
+
|
|
139
|
+
3. **Reference best practices:**
|
|
140
|
+
```
|
|
141
|
+
Review the Stitch Effective Prompting Guide at:
|
|
142
|
+
https://stitch.withgoogle.com/docs/learn/prompting/
|
|
143
|
+
```
|
|
144
|
+
|
|
145
|
+
4. **Analyze and synthesize:**
|
|
146
|
+
- Extract all relevant design tokens from the screen
|
|
147
|
+
- Translate technical values into descriptive language
|
|
148
|
+
- Organize information according to the DESIGN.md structure
|
|
149
|
+
|
|
150
|
+
5. **Generate the file:**
|
|
151
|
+
- Create `DESIGN.md` in the project directory
|
|
152
|
+
- Follow the prescribed format exactly
|
|
153
|
+
- Ensure all color codes are accurate
|
|
154
|
+
- Use evocative, designer-friendly language
|
|
155
|
+
|
|
156
|
+
## Best Practices
|
|
157
|
+
|
|
158
|
+
- **Be Descriptive:** Avoid generic terms like "blue" or "rounded." Use "Ocean-deep Cerulean (#0077B6)" or "Gently curved edges"
|
|
159
|
+
- **Be Functional:** Always explain what each design element is used for
|
|
160
|
+
- **Be Consistent:** Use the same terminology throughout the document
|
|
161
|
+
- **Be Visual:** Help readers visualize the design through your descriptions
|
|
162
|
+
- **Be Precise:** Include exact values (hex codes, pixel values) in parentheses after natural language descriptions
|
|
163
|
+
|
|
164
|
+
## Tips for Success
|
|
165
|
+
|
|
166
|
+
1. **Start with the big picture:** Understand the overall aesthetic before diving into details
|
|
167
|
+
2. **Look for patterns:** Identify consistent spacing, sizing, and styling patterns
|
|
168
|
+
3. **Think semantically:** Name colors by their purpose, not just their appearance
|
|
169
|
+
4. **Consider hierarchy:** Document how visual weight and importance are communicated
|
|
170
|
+
5. **Reference the guide:** Use language and patterns from the Stitch Effective Prompting Guide
|
|
171
|
+
|
|
172
|
+
## Common Pitfalls to Avoid
|
|
173
|
+
|
|
174
|
+
- ❌ Using technical jargon without translation (e.g., "rounded-xl" instead of "generously rounded corners")
|
|
175
|
+
- ❌ Omitting color codes or using only descriptive names
|
|
176
|
+
- ❌ Forgetting to explain functional roles of design elements
|
|
177
|
+
- ❌ Being too vague in atmosphere descriptions
|
|
178
|
+
- ❌ Ignoring subtle design details like shadows or spacing patterns
|