skill-library-mcp 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.claude/settings.local.json +10 -0
- package/.github/workflows/ci.yml +85 -0
- package/.github/workflows/release.yml +57 -0
- package/.release-please-manifest.json +3 -0
- package/CLAUDE.md +60 -0
- package/LICENSE +21 -0
- package/Makefile +18 -0
- package/README.md +222 -0
- package/dist/index.js +312 -0
- package/docs/architecture.md +61 -0
- package/docs/development.md +83 -0
- package/package.json +29 -0
- package/release-please-config.json +17 -0
- package/scripts/import-skills.ts +103 -0
- package/skills/3d-web-experience/SKILL.md +254 -0
- package/skills/ab-test-setup/SKILL.md +232 -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/SKILL.md +383 -0
- package/skills/activecampaign-automation/SKILL.md +209 -0
- package/skills/address-github-comments/SKILL.md +55 -0
- package/skills/agent-evaluation/SKILL.md +64 -0
- package/skills/agent-manager-skill/SKILL.md +40 -0
- package/skills/agent-memory-mcp/SKILL.md +82 -0
- package/skills/agent-memory-systems/SKILL.md +67 -0
- package/skills/agent-orchestration-improve-agent/SKILL.md +349 -0
- package/skills/agent-orchestration-multi-agent-optimize/SKILL.md +239 -0
- package/skills/agent-tool-builder/SKILL.md +53 -0
- package/skills/ai-agents-architect/SKILL.md +90 -0
- package/skills/ai-engineer/SKILL.md +171 -0
- package/skills/ai-product/SKILL.md +54 -0
- package/skills/ai-wrapper-product/SKILL.md +273 -0
- package/skills/airflow-dag-patterns/SKILL.md +41 -0
- package/skills/airflow-dag-patterns/resources/implementation-playbook.md +509 -0
- package/skills/airtable-automation/SKILL.md +170 -0
- package/skills/algolia-search/SKILL.md +66 -0
- package/skills/algorithmic-art/LICENSE.txt +202 -0
- package/skills/algorithmic-art/SKILL.md +405 -0
- package/skills/algorithmic-art/templates/generator_template.js +223 -0
- package/skills/algorithmic-art/templates/viewer.html +599 -0
- package/skills/amplitude-automation/SKILL.md +216 -0
- package/skills/analytics-tracking/SKILL.md +404 -0
- package/skills/angular/SKILL.md +821 -0
- package/skills/angular-best-practices/SKILL.md +559 -0
- package/skills/angular-migration/SKILL.md +428 -0
- package/skills/angular-state-management/SKILL.md +634 -0
- package/skills/angular-ui-patterns/SKILL.md +508 -0
- package/skills/anti-reversing-techniques/SKILL.md +42 -0
- package/skills/anti-reversing-techniques/resources/implementation-playbook.md +539 -0
- package/skills/antigravity-workflows/SKILL.md +80 -0
- package/skills/antigravity-workflows/resources/implementation-playbook.md +36 -0
- package/skills/api-design-principles/SKILL.md +37 -0
- package/skills/api-design-principles/resources/implementation-playbook.md +513 -0
- package/skills/api-documentation-generator/SKILL.md +484 -0
- package/skills/api-documenter/SKILL.md +184 -0
- package/skills/api-fuzzing-bug-bounty/SKILL.md +433 -0
- package/skills/api-patterns/SKILL.md +81 -0
- package/skills/api-security-best-practices/SKILL.md +907 -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/app-builder/SKILL.md +75 -0
- package/skills/app-store-optimization/SKILL.md +403 -0
- package/skills/application-performance-performance-optimization/SKILL.md +154 -0
- package/skills/architect-review/SKILL.md +174 -0
- package/skills/architecture/SKILL.md +55 -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/asana-automation/SKILL.md +171 -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/audio-transcriber/SKILL.md +558 -0
- package/skills/auth-implementation-patterns/SKILL.md +39 -0
- package/skills/auth-implementation-patterns/resources/implementation-playbook.md +618 -0
- package/skills/automate-whatsapp/SKILL.md +257 -0
- package/skills/autonomous-agent-patterns/SKILL.md +761 -0
- package/skills/autonomous-agents/SKILL.md +68 -0
- package/skills/avalonia-layout-zafiro/SKILL.md +59 -0
- package/skills/avalonia-viewmodels-zafiro/SKILL.md +29 -0
- package/skills/avalonia-zafiro-development/SKILL.md +29 -0
- package/skills/aws-penetration-testing/SKILL.md +405 -0
- package/skills/aws-serverless/SKILL.md +323 -0
- package/skills/aws-skills/SKILL.md +22 -0
- package/skills/azure-functions/SKILL.md +42 -0
- package/skills/backend-architect/SKILL.md +333 -0
- package/skills/backend-dev-guidelines/SKILL.md +342 -0
- package/skills/backend-dev-guidelines/resources/architecture-overview.md +451 -0
- package/skills/backend-dev-guidelines/resources/async-and-errors.md +307 -0
- package/skills/backend-dev-guidelines/resources/complete-examples.md +638 -0
- package/skills/backend-dev-guidelines/resources/configuration.md +275 -0
- package/skills/backend-dev-guidelines/resources/database-patterns.md +224 -0
- package/skills/backend-dev-guidelines/resources/middleware-guide.md +213 -0
- package/skills/backend-dev-guidelines/resources/routing-and-controllers.md +756 -0
- package/skills/backend-dev-guidelines/resources/sentry-and-monitoring.md +336 -0
- package/skills/backend-dev-guidelines/resources/services-and-repositories.md +789 -0
- package/skills/backend-dev-guidelines/resources/testing-guide.md +235 -0
- package/skills/backend-dev-guidelines/resources/validation-patterns.md +754 -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/bamboohr-automation/SKILL.md +220 -0
- package/skills/basecamp-automation/SKILL.md +234 -0
- package/skills/bash-defensive-patterns/SKILL.md +43 -0
- package/skills/bash-defensive-patterns/resources/implementation-playbook.md +517 -0
- package/skills/bash-linux/SKILL.md +199 -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/behavioral-modes/SKILL.md +242 -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/bitbucket-automation/SKILL.md +224 -0
- package/skills/blockchain-developer/SKILL.md +208 -0
- package/skills/blockrun/SKILL.md +292 -0
- package/skills/box-automation/SKILL.md +233 -0
- package/skills/brainstorming/SKILL.md +230 -0
- package/skills/brand-guidelines-anthropic/SKILL.md +73 -0
- package/skills/brevo-automation/SKILL.md +197 -0
- package/skills/broken-authentication/SKILL.md +476 -0
- package/skills/browser-automation/SKILL.md +70 -0
- package/skills/browser-extension-builder/SKILL.md +261 -0
- package/skills/bullmq-specialist/SKILL.md +57 -0
- package/skills/bun-development/SKILL.md +691 -0
- package/skills/burp-suite-testing/SKILL.md +380 -0
- package/skills/business-analyst/SKILL.md +182 -0
- package/skills/busybox-on-windows/SKILL.md +30 -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/cal-com-automation/SKILL.md +203 -0
- package/skills/calendly-automation/SKILL.md +211 -0
- package/skills/canva-automation/SKILL.md +217 -0
- package/skills/canvas-design/LICENSE.txt +202 -0
- package/skills/canvas-design/SKILL.md +130 -0
- package/skills/canvas-design/canvas-fonts/ArsenalSC-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/ArsenalSC-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/BigShoulders-Bold.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/BigShoulders-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/BigShoulders-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/Boldonse-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/Boldonse-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/BricolageGrotesque-Bold.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/BricolageGrotesque-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/BricolageGrotesque-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/CrimsonPro-Bold.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/CrimsonPro-Italic.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/CrimsonPro-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/CrimsonPro-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/DMMono-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/DMMono-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/EricaOne-OFL.txt +94 -0
- package/skills/canvas-design/canvas-fonts/EricaOne-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/GeistMono-Bold.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/GeistMono-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/GeistMono-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/Gloock-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/Gloock-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/IBMPlexMono-Bold.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/IBMPlexMono-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/IBMPlexMono-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/IBMPlexSerif-Bold.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/IBMPlexSerif-BoldItalic.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/IBMPlexSerif-Italic.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/IBMPlexSerif-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/InstrumentSans-Bold.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/InstrumentSans-BoldItalic.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/InstrumentSans-Italic.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/InstrumentSans-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/InstrumentSans-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/InstrumentSerif-Italic.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/InstrumentSerif-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/Italiana-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/Italiana-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/JetBrainsMono-Bold.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/JetBrainsMono-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/JetBrainsMono-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/Jura-Light.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/Jura-Medium.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/Jura-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/LibreBaskerville-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/LibreBaskerville-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/Lora-Bold.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/Lora-BoldItalic.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/Lora-Italic.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/Lora-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/Lora-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/NationalPark-Bold.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/NationalPark-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/NationalPark-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/NothingYouCouldDo-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/NothingYouCouldDo-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/Outfit-Bold.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/Outfit-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/Outfit-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/PixelifySans-Medium.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/PixelifySans-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/PoiretOne-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/PoiretOne-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/RedHatMono-Bold.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/RedHatMono-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/RedHatMono-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/Silkscreen-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/Silkscreen-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/SmoochSans-Medium.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/SmoochSans-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/Tektur-Medium.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/Tektur-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/Tektur-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/WorkSans-Bold.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/WorkSans-BoldItalic.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/WorkSans-Italic.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/WorkSans-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/WorkSans-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/YoungSerif-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/YoungSerif-Regular.ttf +0 -0
- package/skills/cc-skill-backend-patterns/SKILL.md +584 -0
- package/skills/cc-skill-clickhouse-io/SKILL.md +431 -0
- package/skills/cc-skill-coding-standards/SKILL.md +522 -0
- package/skills/cc-skill-continuous-learning/SKILL.md +10 -0
- package/skills/cc-skill-frontend-patterns/SKILL.md +633 -0
- package/skills/cc-skill-project-guidelines-example/SKILL.md +352 -0
- package/skills/cc-skill-security-review/SKILL.md +496 -0
- package/skills/cc-skill-strategic-compact/SKILL.md +10 -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/circleci-automation/SKILL.md +177 -0
- package/skills/clarity-gate/SKILL.md +22 -0
- package/skills/claude-ally-health/SKILL.md +22 -0
- package/skills/claude-code-guide/SKILL.md +68 -0
- package/skills/claude-d3js-skill/SKILL.md +820 -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/clean-code/SKILL.md +94 -0
- package/skills/clerk-auth/SKILL.md +56 -0
- package/skills/clickup-automation/SKILL.md +234 -0
- package/skills/close-automation/SKILL.md +212 -0
- package/skills/cloud-architect/SKILL.md +135 -0
- package/skills/cloud-penetration-testing/SKILL.md +501 -0
- package/skills/coda-automation/SKILL.md +241 -0
- 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-checklist/SKILL.md +444 -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 +178 -0
- 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/codex-review/SKILL.md +37 -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/competitor-alternatives/SKILL.md +750 -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/computer-use-agents/SKILL.md +315 -0
- package/skills/computer-vision-expert/SKILL.md +70 -0
- package/skills/concise-planning/SKILL.md +62 -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/confluence-automation/SKILL.md +208 -0
- package/skills/content-creator/SKILL.md +248 -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/context-window-management/SKILL.md +53 -0
- package/skills/context7-auto-research/SKILL.md +36 -0
- package/skills/conversation-memory/SKILL.md +61 -0
- package/skills/convertkit-automation/SKILL.md +195 -0
- package/skills/copy-editing/SKILL.md +439 -0
- package/skills/copywriting/SKILL.md +225 -0
- package/skills/core-components/SKILL.md +264 -0
- package/skills/cost-optimization/SKILL.md +286 -0
- package/skills/cpp-pro/SKILL.md +59 -0
- 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/crewai/SKILL.md +243 -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 +356 -0
- 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-design/SKILL.md +52 -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 +167 -0
- package/skills/datadog-automation/SKILL.md +235 -0
- 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-procedures/SKILL.md +241 -0
- package/skills/deployment-validation-config-validate/SKILL.md +496 -0
- package/skills/design-md/SKILL.md +178 -0
- package/skills/design-orchestration/SKILL.md +167 -0
- package/skills/devops-troubleshooter/SKILL.md +161 -0
- package/skills/discord-automation/SKILL.md +187 -0
- package/skills/discord-bot-architect/SKILL.md +277 -0
- package/skills/dispatching-parallel-agents/SKILL.md +180 -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/doc-coauthoring/SKILL.md +375 -0
- package/skills/docker-expert/SKILL.md +409 -0
- package/skills/docs-architect/SKILL.md +98 -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/documentation-templates/SKILL.md +194 -0
- package/skills/docusign-automation/SKILL.md +208 -0
- package/skills/dotnet-architect/SKILL.md +197 -0
- package/skills/dotnet-backend/SKILL.md +266 -0
- package/skills/dotnet-backend-patterns/SKILL.md +37 -0
- package/skills/dotnet-backend-patterns/resources/implementation-playbook.md +799 -0
- package/skills/dropbox-automation/SKILL.md +230 -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/email-sequence/SKILL.md +925 -0
- package/skills/email-systems/SKILL.md +54 -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/environment-setup-guide/SKILL.md +479 -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/ethical-hacking-methodology/SKILL.md +466 -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/exa-search/SKILL.md +36 -0
- package/skills/executing-plans/SKILL.md +76 -0
- package/skills/expo-deployment/SKILL.md +72 -0
- 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/figma-automation/SKILL.md +181 -0
- package/skills/file-organizer/SKILL.md +250 -0
- package/skills/file-path-traversal/SKILL.md +486 -0
- package/skills/file-uploads/SKILL.md +22 -0
- package/skills/find-bugs/SKILL.md +86 -0
- package/skills/finishing-a-development-branch/SKILL.md +200 -0
- package/skills/firebase/SKILL.md +56 -0
- package/skills/firecrawl-scraper/SKILL.md +37 -0
- package/skills/firmware-analyst/SKILL.md +320 -0
- package/skills/fix-review/SKILL.md +53 -0
- package/skills/flutter-expert/SKILL.md +200 -0
- package/skills/form-cro/SKILL.md +441 -0
- 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/free-tool-strategy/SKILL.md +576 -0
- package/skills/freshdesk-automation/SKILL.md +219 -0
- package/skills/freshservice-automation/SKILL.md +213 -0
- package/skills/frontend-design/LICENSE.txt +177 -0
- package/skills/frontend-design/SKILL.md +42 -0
- package/skills/frontend-dev-guidelines/SKILL.md +359 -0
- package/skills/frontend-dev-guidelines/resources/common-patterns.md +331 -0
- package/skills/frontend-dev-guidelines/resources/complete-examples.md +872 -0
- package/skills/frontend-dev-guidelines/resources/component-patterns.md +502 -0
- package/skills/frontend-dev-guidelines/resources/data-fetching.md +767 -0
- package/skills/frontend-dev-guidelines/resources/file-organization.md +502 -0
- package/skills/frontend-dev-guidelines/resources/loading-and-error-states.md +501 -0
- package/skills/frontend-dev-guidelines/resources/performance.md +406 -0
- package/skills/frontend-dev-guidelines/resources/routing-guide.md +364 -0
- package/skills/frontend-dev-guidelines/resources/styling-guide.md +428 -0
- package/skills/frontend-dev-guidelines/resources/typescript-standards.md +418 -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/game-development/SKILL.md +167 -0
- package/skills/gcp-cloud-run/SKILL.md +288 -0
- package/skills/gdpr-data-handling/SKILL.md +33 -0
- package/skills/gdpr-data-handling/resources/implementation-playbook.md +615 -0
- package/skills/geo-fundamentals/SKILL.md +156 -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/git-pushing/SKILL.md +33 -0
- package/skills/github-actions-templates/SKILL.md +345 -0
- package/skills/github-automation/SKILL.md +227 -0
- package/skills/github-workflow-automation/SKILL.md +846 -0
- package/skills/gitlab-automation/SKILL.md +254 -0
- package/skills/gitlab-ci-patterns/SKILL.md +283 -0
- package/skills/gitops-workflow/SKILL.md +303 -0
- package/skills/gmail-automation/SKILL.md +270 -0
- package/skills/go-concurrency-patterns/SKILL.md +33 -0
- package/skills/go-concurrency-patterns/resources/implementation-playbook.md +654 -0
- package/skills/go-playwright/SKILL.md +76 -0
- package/skills/go-playwright/resources/implementation-playbook.md +110 -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 +179 -0
- package/skills/google-analytics-automation/SKILL.md +227 -0
- package/skills/google-calendar-automation/SKILL.md +176 -0
- package/skills/google-drive-automation/SKILL.md +193 -0
- package/skills/googlesheets-automation/SKILL.md +197 -0
- package/skills/grafana-dashboards/SKILL.md +381 -0
- package/skills/graphql/SKILL.md +68 -0
- package/skills/graphql-architect/SKILL.md +182 -0
- package/skills/haskell-pro/SKILL.md +56 -0
- package/skills/helm-chart-scaffolding/SKILL.md +34 -0
- package/skills/helm-chart-scaffolding/resources/implementation-playbook.md +543 -0
- package/skills/helpdesk-automation/SKILL.md +166 -0
- package/skills/hr-pro/SKILL.md +126 -0
- package/skills/html-injection-testing/SKILL.md +498 -0
- package/skills/hubspot-automation/SKILL.md +178 -0
- package/skills/hubspot-integration/SKILL.md +42 -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/i18n-localization/SKILL.md +154 -0
- package/skills/idor-testing/SKILL.md +442 -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/inngest/SKILL.md +55 -0
- package/skills/instagram-automation/SKILL.md +192 -0
- package/skills/interactive-portfolio/SKILL.md +223 -0
- package/skills/intercom-automation/SKILL.md +248 -0
- package/skills/internal-comms-anthropic/SKILL.md +32 -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-mastery/SKILL.md +645 -0
- package/skills/javascript-pro/SKILL.md +57 -0
- 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/jira-automation/SKILL.md +185 -0
- package/skills/julia-pro/SKILL.md +209 -0
- package/skills/k8s-manifest-generator/SKILL.md +35 -0
- package/skills/k8s-manifest-generator/resources/implementation-playbook.md +510 -0
- package/skills/k8s-security-policies/SKILL.md +346 -0
- package/skills/kaizen/SKILL.md +730 -0
- package/skills/klaviyo-automation/SKILL.md +190 -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/langfuse/SKILL.md +238 -0
- package/skills/langgraph/SKILL.md +287 -0
- package/skills/last30days/SKILL.md +421 -0
- package/skills/launch-strategy/SKILL.md +344 -0
- package/skills/legacy-modernizer/SKILL.md +53 -0
- package/skills/legal-advisor/SKILL.md +70 -0
- package/skills/linear-automation/SKILL.md +178 -0
- package/skills/linear-claude-skill/SKILL.md +543 -0
- package/skills/linkedin-automation/SKILL.md +175 -0
- package/skills/linkerd-patterns/SKILL.md +321 -0
- package/skills/lint-and-validate/SKILL.md +45 -0
- package/skills/linux-privilege-escalation/SKILL.md +504 -0
- package/skills/linux-shell-scripting/SKILL.md +504 -0
- package/skills/llm-app-patterns/SKILL.md +760 -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/SKILL.md +721 -0
- package/skills/machine-learning-ops-ml-pipeline/SKILL.md +314 -0
- package/skills/mailchimp-automation/SKILL.md +231 -0
- package/skills/make-automation/SKILL.md +201 -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/marketing-ideas/SKILL.md +221 -0
- package/skills/marketing-psychology/SKILL.md +255 -0
- package/skills/mcp-builder/LICENSE.txt +202 -0
- package/skills/mcp-builder/SKILL.md +236 -0
- package/skills/mcp-builder/resources/evaluation.md +602 -0
- package/skills/mcp-builder/resources/mcp_best_practices.md +249 -0
- package/skills/mcp-builder/resources/node_mcp_server.md +970 -0
- package/skills/mcp-builder/resources/python_mcp_server.md +719 -0
- package/skills/mcp-builder/scripts/connections.py +151 -0
- package/skills/mcp-builder/scripts/evaluation.py +373 -0
- package/skills/mcp-builder/scripts/example_evaluation.xml +22 -0
- package/skills/mcp-builder/scripts/requirements.txt +2 -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/metasploit-framework/SKILL.md +478 -0
- package/skills/micro-saas-launcher/SKILL.md +212 -0
- package/skills/microservices-patterns/SKILL.md +35 -0
- package/skills/microservices-patterns/resources/implementation-playbook.md +607 -0
- package/skills/microsoft-teams-automation/SKILL.md +211 -0
- package/skills/minecraft-bukkit-pro/SKILL.md +126 -0
- package/skills/miro-automation/SKILL.md +205 -0
- package/skills/mixpanel-automation/SKILL.md +224 -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-design/SKILL.md +284 -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/monday-automation/SKILL.md +233 -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/moodle-external-api-development/SKILL.md +597 -0
- package/skills/mtls-configuration/SKILL.md +359 -0
- package/skills/multi-agent-brainstorming/SKILL.md +256 -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/neon-postgres/SKILL.md +56 -0
- package/skills/nestjs-expert/SKILL.md +552 -0
- package/skills/network-101/SKILL.md +342 -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/nextjs-best-practices/SKILL.md +203 -0
- package/skills/nextjs-supabase-auth/SKILL.md +56 -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/nodejs-best-practices/SKILL.md +333 -0
- package/skills/nosql-expert/SKILL.md +111 -0
- package/skills/notebooklm/SKILL.md +269 -0
- package/skills/notion-automation/SKILL.md +215 -0
- package/skills/notion-template-business/SKILL.md +216 -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/obsidian-clipper-template-creator/SKILL.md +64 -0
- package/skills/on-call-handoff-patterns/SKILL.md +453 -0
- package/skills/onboarding-cro/SKILL.md +433 -0
- package/skills/one-drive-automation/SKILL.md +238 -0
- package/skills/openapi-spec-generation/SKILL.md +33 -0
- package/skills/openapi-spec-generation/resources/implementation-playbook.md +1027 -0
- package/skills/oss-hunter/SKILL.md +75 -0
- package/skills/outlook-automation/SKILL.md +191 -0
- package/skills/outlook-calendar-automation/SKILL.md +236 -0
- package/skills/page-cro/SKILL.md +343 -0
- package/skills/pagerduty-automation/SKILL.md +245 -0
- package/skills/paid-ads/SKILL.md +551 -0
- package/skills/parallel-agents/SKILL.md +175 -0
- package/skills/payment-integration/SKILL.md +77 -0
- package/skills/paypal-integration/SKILL.md +479 -0
- package/skills/paywall-upgrade-cro/SKILL.md +570 -0
- package/skills/pci-compliance/SKILL.md +478 -0
- package/skills/pentest-checklist/SKILL.md +334 -0
- package/skills/pentest-commands/SKILL.md +438 -0
- package/skills/performance-engineer/SKILL.md +180 -0
- package/skills/performance-profiling/SKILL.md +143 -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/personal-tool-builder/SKILL.md +289 -0
- package/skills/php-pro/SKILL.md +63 -0
- package/skills/pipedrive-automation/SKILL.md +224 -0
- package/skills/plaid-fintech/SKILL.md +50 -0
- package/skills/plan-writing/SKILL.md +152 -0
- package/skills/planning-with-files/SKILL.md +211 -0
- package/skills/playwright-skill/SKILL.md +453 -0
- package/skills/popup-cro/SKILL.md +346 -0
- package/skills/posix-shell-pro/SKILL.md +304 -0
- package/skills/postgres-best-practices/SKILL.md +57 -0
- package/skills/postgresql/SKILL.md +230 -0
- package/skills/posthog-automation/SKILL.md +224 -0
- package/skills/postmark-automation/SKILL.md +187 -0
- package/skills/postmortem-writing/SKILL.md +386 -0
- package/skills/powershell-windows/SKILL.md +167 -0
- package/skills/pricing-strategy/SKILL.md +356 -0
- package/skills/prisma-expert/SKILL.md +355 -0
- package/skills/privilege-escalation-methods/SKILL.md +333 -0
- package/skills/product-manager-toolkit/SKILL.md +351 -0
- package/skills/production-code-audit/SKILL.md +540 -0
- package/skills/programmatic-seo/SKILL.md +351 -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-caching/SKILL.md +61 -0
- package/skills/prompt-engineer/SKILL.md +252 -0
- package/skills/prompt-engineering/SKILL.md +171 -0
- package/skills/prompt-engineering-patterns/SKILL.md +213 -0
- package/skills/prompt-library/SKILL.md +322 -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-patterns/SKILL.md +441 -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 +158 -0
- 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/rag-engineer/SKILL.md +90 -0
- package/skills/rag-implementation/SKILL.md +421 -0
- package/skills/react-best-practices/SKILL.md +121 -0
- 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-patterns/SKILL.md +198 -0
- package/skills/react-state-management/SKILL.md +441 -0
- package/skills/react-ui-patterns/SKILL.md +289 -0
- package/skills/readme/SKILL.md +842 -0
- package/skills/receiving-code-review/SKILL.md +213 -0
- package/skills/red-team-tactics/SKILL.md +199 -0
- package/skills/red-team-tools/SKILL.md +310 -0
- package/skills/reddit-automation/SKILL.md +212 -0
- package/skills/reference-builder/SKILL.md +188 -0
- package/skills/referral-program/SKILL.md +602 -0
- package/skills/remotion-best-practices/SKILL.md +45 -0
- package/skills/render-automation/SKILL.md +181 -0
- package/skills/requesting-code-review/SKILL.md +105 -0
- package/skills/research-engineer/SKILL.md +135 -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/salesforce-automation/SKILL.md +190 -0
- package/skills/salesforce-development/SKILL.md +51 -0
- package/skills/sast-configuration/SKILL.md +212 -0
- package/skills/scala-pro/SKILL.md +82 -0
- package/skills/scanning-tools/SKILL.md +589 -0
- package/skills/schema-markup/SKILL.md +360 -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/scroll-experience/SKILL.md +263 -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/segment-automation/SKILL.md +225 -0
- package/skills/segment-cdp/SKILL.md +50 -0
- package/skills/sendgrid-automation/SKILL.md +228 -0
- package/skills/senior-architect/SKILL.md +209 -0
- package/skills/senior-fullstack/SKILL.md +209 -0
- package/skills/sentry-automation/SKILL.md +232 -0
- package/skills/seo-audit/SKILL.md +487 -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-fundamentals/SKILL.md +173 -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/server-management/SKILL.md +161 -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/shodan-reconnaissance/SKILL.md +503 -0
- package/skills/shopify-apps/SKILL.md +42 -0
- package/skills/shopify-automation/SKILL.md +168 -0
- package/skills/shopify-development/SKILL.md +366 -0
- package/skills/signup-flow-cro/SKILL.md +355 -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/LICENSE.txt +202 -0
- package/skills/skill-creator/SKILL.md +357 -0
- package/skills/skill-creator/resources/output-patterns.md +82 -0
- package/skills/skill-creator/resources/workflows.md +28 -0
- package/skills/skill-creator/scripts/init_skill.py +303 -0
- package/skills/skill-creator/scripts/package_skill.py +110 -0
- package/skills/skill-creator/scripts/quick_validate.py +103 -0
- package/skills/skill-developer/SKILL.md +426 -0
- package/skills/skill-rails-upgrade/SKILL.md +408 -0
- package/skills/skill-seekers/SKILL.md +22 -0
- package/skills/slack-automation/SKILL.md +189 -0
- package/skills/slack-bot-builder/SKILL.md +264 -0
- package/skills/slack-gif-creator/LICENSE.txt +202 -0
- package/skills/slack-gif-creator/SKILL.md +254 -0
- package/skills/slack-gif-creator/core/easing.py +234 -0
- package/skills/slack-gif-creator/core/frame_composer.py +176 -0
- package/skills/slack-gif-creator/core/gif_builder.py +269 -0
- package/skills/slack-gif-creator/core/validators.py +136 -0
- package/skills/slack-gif-creator/requirements.txt +4 -0
- package/skills/slo-implementation/SKILL.md +341 -0
- package/skills/smtp-penetration-testing/SKILL.md +500 -0
- package/skills/social-content/SKILL.md +807 -0
- package/skills/software-architecture/SKILL.md +75 -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-injection-testing/SKILL.md +448 -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 +173 -0
- package/skills/sqlmap-database-pentesting/SKILL.md +400 -0
- package/skills/square-automation/SKILL.md +176 -0
- package/skills/ssh-penetration-testing/SKILL.md +488 -0
- 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/SKILL.md +378 -0
- package/skills/stride-analysis-patterns/SKILL.md +33 -0
- package/skills/stride-analysis-patterns/resources/implementation-playbook.md +655 -0
- package/skills/stripe-automation/SKILL.md +198 -0
- package/skills/stripe-integration/SKILL.md +454 -0
- package/skills/subagent-driven-development/SKILL.md +240 -0
- package/skills/supabase-automation/SKILL.md +236 -0
- package/skills/superpowers-lab/SKILL.md +22 -0
- package/skills/swiftui-expert-skill/SKILL.md +275 -0
- package/skills/systematic-debugging/SKILL.md +296 -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/tailwind-patterns/SKILL.md +269 -0
- package/skills/tavily-web/SKILL.md +36 -0
- package/skills/tdd-orchestrator/SKILL.md +205 -0
- package/skills/tdd-workflow/SKILL.md +149 -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/telegram-automation/SKILL.md +219 -0
- package/skills/telegram-bot-builder/SKILL.md +254 -0
- package/skills/telegram-mini-app/SKILL.md +279 -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-skill/SKILL.md +517 -0
- package/skills/terraform-specialist/SKILL.md +166 -0
- package/skills/test-automator/SKILL.md +224 -0
- package/skills/test-driven-development/SKILL.md +371 -0
- package/skills/test-fixing/SKILL.md +119 -0
- package/skills/testing-patterns/SKILL.md +259 -0
- package/skills/theme-factory/LICENSE.txt +202 -0
- package/skills/theme-factory/SKILL.md +59 -0
- package/skills/theme-factory/theme-showcase.pdf +0 -0
- package/skills/theme-factory/themes/arctic-frost.md +19 -0
- package/skills/theme-factory/themes/botanical-garden.md +19 -0
- package/skills/theme-factory/themes/desert-rose.md +19 -0
- package/skills/theme-factory/themes/forest-canopy.md +19 -0
- package/skills/theme-factory/themes/golden-hour.md +19 -0
- package/skills/theme-factory/themes/midnight-galaxy.md +19 -0
- package/skills/theme-factory/themes/modern-minimalist.md +19 -0
- package/skills/theme-factory/themes/ocean-depths.md +19 -0
- package/skills/theme-factory/themes/sunset-boulevard.md +19 -0
- package/skills/theme-factory/themes/tech-innovation.md +19 -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/tiktok-automation/SKILL.md +178 -0
- package/skills/todoist-automation/SKILL.md +231 -0
- package/skills/tool-design/SKILL.md +318 -0
- package/skills/top-web-vulnerabilities/SKILL.md +543 -0
- package/skills/track-management/SKILL.md +38 -0
- package/skills/track-management/resources/implementation-playbook.md +591 -0
- package/skills/trello-automation/SKILL.md +181 -0
- package/skills/trigger-dev/SKILL.md +67 -0
- package/skills/turborepo-caching/SKILL.md +419 -0
- package/skills/tutorial-engineer/SKILL.md +139 -0
- package/skills/twilio-communications/SKILL.md +295 -0
- package/skills/twitter-automation/SKILL.md +231 -0
- package/skills/typescript-advanced-types/SKILL.md +35 -0
- package/skills/typescript-advanced-types/resources/implementation-playbook.md +716 -0
- package/skills/typescript-expert/SKILL.md +429 -0
- package/skills/typescript-pro/SKILL.md +55 -0
- 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 -0
- 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/upgrading-expo/SKILL.md +118 -0
- package/skills/upstash-qstash/SKILL.md +68 -0
- package/skills/using-git-worktrees/SKILL.md +217 -0
- package/skills/using-neon/SKILL.md +84 -0
- package/skills/using-superpowers/SKILL.md +87 -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-automation/SKILL.md +226 -0
- package/skills/vercel-deploy-claimable/SKILL.md +123 -0
- package/skills/vercel-deployment/SKILL.md +79 -0
- package/skills/verification-before-completion/SKILL.md +139 -0
- package/skills/vexor/SKILL.md +22 -0
- package/skills/viral-generator-builder/SKILL.md +199 -0
- package/skills/voice-agents/SKILL.md +68 -0
- package/skills/voice-ai-development/SKILL.md +302 -0
- package/skills/voice-ai-engine-development/SKILL.md +721 -0
- package/skills/vulnerability-scanner/SKILL.md +276 -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/LICENSE.txt +202 -0
- package/skills/web-artifacts-builder/SKILL.md +74 -0
- package/skills/web-artifacts-builder/scripts/bundle-artifact.sh +54 -0
- package/skills/web-artifacts-builder/scripts/init-artifact.sh +322 -0
- package/skills/web-artifacts-builder/scripts/shadcn-components.tar.gz +0 -0
- package/skills/web-design-guidelines/SKILL.md +36 -0
- package/skills/web-performance-optimization/SKILL.md +646 -0
- package/skills/web3-testing/SKILL.md +427 -0
- package/skills/webapp-testing/LICENSE.txt +202 -0
- package/skills/webapp-testing/SKILL.md +96 -0
- package/skills/webapp-testing/examples/console_logging.py +35 -0
- package/skills/webapp-testing/examples/element_discovery.py +40 -0
- package/skills/webapp-testing/examples/static_html_automation.py +33 -0
- package/skills/webapp-testing/scripts/with_server.py +106 -0
- package/skills/webflow-automation/SKILL.md +236 -0
- package/skills/whatsapp-automation/SKILL.md +214 -0
- package/skills/windows-privilege-escalation/SKILL.md +496 -0
- package/skills/wireshark-analysis/SKILL.md +497 -0
- package/skills/wordpress-penetration-testing/SKILL.md +485 -0
- package/skills/workflow-automation/SKILL.md +68 -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/wrike-automation/SKILL.md +233 -0
- package/skills/writing-plans/SKILL.md +116 -0
- package/skills/writing-skills/SKILL.md +125 -0
- package/skills/x-article-publisher-skill/SKILL.md +22 -0
- package/skills/xss-html-injection/SKILL.md +499 -0
- package/skills/youtube-automation/SKILL.md +218 -0
- package/skills/youtube-summarizer/SKILL.md +411 -0
- package/skills/zapier-make-patterns/SKILL.md +67 -0
- package/skills/zendesk-automation/SKILL.md +215 -0
- package/skills/zoho-crm-automation/SKILL.md +206 -0
- package/skills/zoom-automation/SKILL.md +217 -0
- package/src/dedup.ts +132 -0
- package/src/index.ts +26 -0
- package/src/loader.ts +33 -0
- package/src/search.ts +83 -0
- package/src/server.ts +83 -0
- package/src/skill-index.ts +105 -0
- package/src/types.ts +28 -0
- package/test/dedup.test.ts +33 -0
- package/test/fixtures/allowed-tools/SKILL.md +9 -0
- package/test/fixtures/basic-skill/SKILL.md +11 -0
- package/test/fixtures/empty-description/SKILL.md +7 -0
- package/test/fixtures/invalid-frontmatter/SKILL.md +7 -0
- package/test/fixtures/multiline-description/SKILL.md +11 -0
- package/test/fixtures/no-frontmatter/SKILL.md +3 -0
- package/test/fixtures/skill-with-hyphenated-resources/SKILL.md +8 -0
- package/test/fixtures/skill-with-hyphenated-resources/resources/implementation-playbook.md +3 -0
- package/test/fixtures/skill-with-hyphenated-resources/resources/quick-start-guide.md +3 -0
- package/test/fixtures/skill-with-resources/SKILL.md +8 -0
- package/test/fixtures/skill-with-resources/resources/examples.md +3 -0
- package/test/fixtures/skill-with-resources/resources/guide.md +3 -0
- package/test/integration.test.ts +148 -0
- package/test/loader.test.ts +78 -0
- package/test/search.test.ts +135 -0
- package/test/server.test.ts +94 -0
- package/test/skill-index.test.ts +144 -0
- package/tsconfig.json +15 -0
- package/tsup.config.ts +12 -0
- package/vitest.config.ts +5 -0
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: software-architecture
|
|
3
|
+
description: Guide for quality focused software architecture. This skill should be used when users want to write code, design architecture, analyze code, in any case that relates to software development.
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Software Architecture Development Skill
|
|
7
|
+
|
|
8
|
+
This skill provides guidance for quality focused software development and architecture. It is based on Clean Architecture and Domain Driven Design principles.
|
|
9
|
+
|
|
10
|
+
## Code Style Rules
|
|
11
|
+
|
|
12
|
+
### General Principles
|
|
13
|
+
|
|
14
|
+
- **Early return pattern**: Always use early returns when possible, over nested conditions for better readability
|
|
15
|
+
- Avoid code duplication through creation of reusable functions and modules
|
|
16
|
+
- Decompose long (more than 80 lines of code) components and functions into multiple smaller components and functions. If they cannot be used anywhere else, keep it in the same file. But if file longer than 200 lines of code, it should be split into multiple files.
|
|
17
|
+
- Use arrow functions instead of function declarations when possible
|
|
18
|
+
|
|
19
|
+
### Best Practices
|
|
20
|
+
|
|
21
|
+
#### Library-First Approach
|
|
22
|
+
|
|
23
|
+
- **ALWAYS search for existing solutions before writing custom code**
|
|
24
|
+
- Check npm for existing libraries that solve the problem
|
|
25
|
+
- Evaluate existing services/SaaS solutions
|
|
26
|
+
- Consider third-party APIs for common functionality
|
|
27
|
+
- Use libraries instead of writing your own utils or helpers. For example, use `cockatiel` instead of writing your own retry logic.
|
|
28
|
+
- **When custom code IS justified:**
|
|
29
|
+
- Specific business logic unique to the domain
|
|
30
|
+
- Performance-critical paths with special requirements
|
|
31
|
+
- When external dependencies would be overkill
|
|
32
|
+
- Security-sensitive code requiring full control
|
|
33
|
+
- When existing solutions don't meet requirements after thorough evaluation
|
|
34
|
+
|
|
35
|
+
#### Architecture and Design
|
|
36
|
+
|
|
37
|
+
- **Clean Architecture & DDD Principles:**
|
|
38
|
+
- Follow domain-driven design and ubiquitous language
|
|
39
|
+
- Separate domain entities from infrastructure concerns
|
|
40
|
+
- Keep business logic independent of frameworks
|
|
41
|
+
- Define use cases clearly and keep them isolated
|
|
42
|
+
- **Naming Conventions:**
|
|
43
|
+
- **AVOID** generic names: `utils`, `helpers`, `common`, `shared`
|
|
44
|
+
- **USE** domain-specific names: `OrderCalculator`, `UserAuthenticator`, `InvoiceGenerator`
|
|
45
|
+
- Follow bounded context naming patterns
|
|
46
|
+
- Each module should have a single, clear purpose
|
|
47
|
+
- **Separation of Concerns:**
|
|
48
|
+
- Do NOT mix business logic with UI components
|
|
49
|
+
- Keep database queries out of controllers
|
|
50
|
+
- Maintain clear boundaries between contexts
|
|
51
|
+
- Ensure proper separation of responsibilities
|
|
52
|
+
|
|
53
|
+
#### Anti-Patterns to Avoid
|
|
54
|
+
|
|
55
|
+
- **NIH (Not Invented Here) Syndrome:**
|
|
56
|
+
- Don't build custom auth when Auth0/Supabase exists
|
|
57
|
+
- Don't write custom state management instead of using Redux/Zustand
|
|
58
|
+
- Don't create custom form validation instead of using established libraries
|
|
59
|
+
- **Poor Architectural Choices:**
|
|
60
|
+
- Mixing business logic with UI components
|
|
61
|
+
- Database queries directly in controllers
|
|
62
|
+
- Lack of clear separation of concerns
|
|
63
|
+
- **Generic Naming Anti-Patterns:**
|
|
64
|
+
- `utils.js` with 50 unrelated functions
|
|
65
|
+
- `helpers/misc.js` as a dumping ground
|
|
66
|
+
- `common/shared.js` with unclear purpose
|
|
67
|
+
- Remember: Every line of custom code is a liability that needs maintenance, testing, and documentation
|
|
68
|
+
|
|
69
|
+
#### Code Quality
|
|
70
|
+
|
|
71
|
+
- Proper error handling with typed catch blocks
|
|
72
|
+
- Break down complex logic into smaller, reusable functions
|
|
73
|
+
- Avoid deep nesting (max 3 levels)
|
|
74
|
+
- Keep functions focused and under 50 lines when possible
|
|
75
|
+
- Keep files focused and under 200 lines of code when possible
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: solidity-security
|
|
3
|
+
description: Master smart contract security best practices to prevent common vulnerabilities and implement secure Solidity patterns. Use when writing smart contracts, auditing existing contracts, or implementing security measures for blockchain applications.
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Solidity Security
|
|
7
|
+
|
|
8
|
+
Master smart contract security best practices, vulnerability prevention, and secure Solidity development patterns.
|
|
9
|
+
|
|
10
|
+
## Use this skill when
|
|
11
|
+
|
|
12
|
+
- Writing secure smart contracts
|
|
13
|
+
- Auditing existing contracts for vulnerabilities
|
|
14
|
+
- Implementing secure DeFi protocols
|
|
15
|
+
- Preventing reentrancy, overflow, and access control issues
|
|
16
|
+
- Optimizing gas usage while maintaining security
|
|
17
|
+
- Preparing contracts for professional audits
|
|
18
|
+
- Understanding common attack vectors
|
|
19
|
+
|
|
20
|
+
## Do not use this skill when
|
|
21
|
+
|
|
22
|
+
- The task is unrelated to solidity security
|
|
23
|
+
- You need a different domain or tool outside this scope
|
|
24
|
+
|
|
25
|
+
## Instructions
|
|
26
|
+
|
|
27
|
+
- Clarify goals, constraints, and required inputs.
|
|
28
|
+
- Apply relevant best practices and validate outcomes.
|
|
29
|
+
- Provide actionable steps and verification.
|
|
30
|
+
- If detailed examples are required, open `resources/implementation-playbook.md`.
|
|
31
|
+
|
|
32
|
+
## Resources
|
|
33
|
+
|
|
34
|
+
- `resources/implementation-playbook.md` for detailed patterns and examples.
|
|
@@ -0,0 +1,524 @@
|
|
|
1
|
+
# Solidity Security Implementation Playbook
|
|
2
|
+
|
|
3
|
+
This file contains detailed patterns, checklists, and code samples referenced by the skill.
|
|
4
|
+
|
|
5
|
+
# Solidity Security
|
|
6
|
+
|
|
7
|
+
Master smart contract security best practices, vulnerability prevention, and secure Solidity development patterns.
|
|
8
|
+
|
|
9
|
+
## When to Use This Skill
|
|
10
|
+
|
|
11
|
+
- Writing secure smart contracts
|
|
12
|
+
- Auditing existing contracts for vulnerabilities
|
|
13
|
+
- Implementing secure DeFi protocols
|
|
14
|
+
- Preventing reentrancy, overflow, and access control issues
|
|
15
|
+
- Optimizing gas usage while maintaining security
|
|
16
|
+
- Preparing contracts for professional audits
|
|
17
|
+
- Understanding common attack vectors
|
|
18
|
+
|
|
19
|
+
## Critical Vulnerabilities
|
|
20
|
+
|
|
21
|
+
### 1. Reentrancy
|
|
22
|
+
|
|
23
|
+
Attacker calls back into your contract before state is updated.
|
|
24
|
+
|
|
25
|
+
**Vulnerable Code:**
|
|
26
|
+
|
|
27
|
+
```solidity
|
|
28
|
+
// VULNERABLE TO REENTRANCY
|
|
29
|
+
contract VulnerableBank {
|
|
30
|
+
mapping(address => uint256) public balances;
|
|
31
|
+
|
|
32
|
+
function withdraw() public {
|
|
33
|
+
uint256 amount = balances[msg.sender];
|
|
34
|
+
|
|
35
|
+
// DANGER: External call before state update
|
|
36
|
+
(bool success, ) = msg.sender.call{value: amount}("");
|
|
37
|
+
require(success);
|
|
38
|
+
|
|
39
|
+
balances[msg.sender] = 0; // Too late!
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
```
|
|
43
|
+
|
|
44
|
+
**Secure Pattern (Checks-Effects-Interactions):**
|
|
45
|
+
|
|
46
|
+
```solidity
|
|
47
|
+
contract SecureBank {
|
|
48
|
+
mapping(address => uint256) public balances;
|
|
49
|
+
|
|
50
|
+
function withdraw() public {
|
|
51
|
+
uint256 amount = balances[msg.sender];
|
|
52
|
+
require(amount > 0, "Insufficient balance");
|
|
53
|
+
|
|
54
|
+
// EFFECTS: Update state BEFORE external call
|
|
55
|
+
balances[msg.sender] = 0;
|
|
56
|
+
|
|
57
|
+
// INTERACTIONS: External call last
|
|
58
|
+
(bool success, ) = msg.sender.call{value: amount}("");
|
|
59
|
+
require(success, "Transfer failed");
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
```
|
|
63
|
+
|
|
64
|
+
**Alternative: ReentrancyGuard**
|
|
65
|
+
|
|
66
|
+
```solidity
|
|
67
|
+
import "@openzeppelin/contracts/security/ReentrancyGuard.sol";
|
|
68
|
+
|
|
69
|
+
contract SecureBank is ReentrancyGuard {
|
|
70
|
+
mapping(address => uint256) public balances;
|
|
71
|
+
|
|
72
|
+
function withdraw() public nonReentrant {
|
|
73
|
+
uint256 amount = balances[msg.sender];
|
|
74
|
+
require(amount > 0, "Insufficient balance");
|
|
75
|
+
|
|
76
|
+
balances[msg.sender] = 0;
|
|
77
|
+
|
|
78
|
+
(bool success, ) = msg.sender.call{value: amount}("");
|
|
79
|
+
require(success, "Transfer failed");
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
```
|
|
83
|
+
|
|
84
|
+
### 2. Integer Overflow/Underflow
|
|
85
|
+
|
|
86
|
+
**Vulnerable Code (Solidity < 0.8.0):**
|
|
87
|
+
|
|
88
|
+
```solidity
|
|
89
|
+
// VULNERABLE
|
|
90
|
+
contract VulnerableToken {
|
|
91
|
+
mapping(address => uint256) public balances;
|
|
92
|
+
|
|
93
|
+
function transfer(address to, uint256 amount) public {
|
|
94
|
+
// No overflow check - can wrap around
|
|
95
|
+
balances[msg.sender] -= amount; // Can underflow!
|
|
96
|
+
balances[to] += amount; // Can overflow!
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
```
|
|
100
|
+
|
|
101
|
+
**Secure Pattern (Solidity >= 0.8.0):**
|
|
102
|
+
|
|
103
|
+
```solidity
|
|
104
|
+
// Solidity 0.8+ has built-in overflow/underflow checks
|
|
105
|
+
contract SecureToken {
|
|
106
|
+
mapping(address => uint256) public balances;
|
|
107
|
+
|
|
108
|
+
function transfer(address to, uint256 amount) public {
|
|
109
|
+
// Automatically reverts on overflow/underflow
|
|
110
|
+
balances[msg.sender] -= amount;
|
|
111
|
+
balances[to] += amount;
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
```
|
|
115
|
+
|
|
116
|
+
**For Solidity < 0.8.0, use SafeMath:**
|
|
117
|
+
|
|
118
|
+
```solidity
|
|
119
|
+
import "@openzeppelin/contracts/utils/math/SafeMath.sol";
|
|
120
|
+
|
|
121
|
+
contract SecureToken {
|
|
122
|
+
using SafeMath for uint256;
|
|
123
|
+
mapping(address => uint256) public balances;
|
|
124
|
+
|
|
125
|
+
function transfer(address to, uint256 amount) public {
|
|
126
|
+
balances[msg.sender] = balances[msg.sender].sub(amount);
|
|
127
|
+
balances[to] = balances[to].add(amount);
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
```
|
|
131
|
+
|
|
132
|
+
### 3. Access Control
|
|
133
|
+
|
|
134
|
+
**Vulnerable Code:**
|
|
135
|
+
|
|
136
|
+
```solidity
|
|
137
|
+
// VULNERABLE: Anyone can call critical functions
|
|
138
|
+
contract VulnerableContract {
|
|
139
|
+
address public owner;
|
|
140
|
+
|
|
141
|
+
function withdraw(uint256 amount) public {
|
|
142
|
+
// No access control!
|
|
143
|
+
payable(msg.sender).transfer(amount);
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
```
|
|
147
|
+
|
|
148
|
+
**Secure Pattern:**
|
|
149
|
+
|
|
150
|
+
```solidity
|
|
151
|
+
import "@openzeppelin/contracts/access/Ownable.sol";
|
|
152
|
+
|
|
153
|
+
contract SecureContract is Ownable {
|
|
154
|
+
function withdraw(uint256 amount) public onlyOwner {
|
|
155
|
+
payable(owner()).transfer(amount);
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
// Or implement custom role-based access
|
|
160
|
+
contract RoleBasedContract {
|
|
161
|
+
mapping(address => bool) public admins;
|
|
162
|
+
|
|
163
|
+
modifier onlyAdmin() {
|
|
164
|
+
require(admins[msg.sender], "Not an admin");
|
|
165
|
+
_;
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
function criticalFunction() public onlyAdmin {
|
|
169
|
+
// Protected function
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
```
|
|
173
|
+
|
|
174
|
+
### 4. Front-Running
|
|
175
|
+
|
|
176
|
+
**Vulnerable:**
|
|
177
|
+
|
|
178
|
+
```solidity
|
|
179
|
+
// VULNERABLE TO FRONT-RUNNING
|
|
180
|
+
contract VulnerableDEX {
|
|
181
|
+
function swap(uint256 amount, uint256 minOutput) public {
|
|
182
|
+
// Attacker sees this in mempool and front-runs
|
|
183
|
+
uint256 output = calculateOutput(amount);
|
|
184
|
+
require(output >= minOutput, "Slippage too high");
|
|
185
|
+
// Perform swap
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
```
|
|
189
|
+
|
|
190
|
+
**Mitigation:**
|
|
191
|
+
|
|
192
|
+
```solidity
|
|
193
|
+
contract SecureDEX {
|
|
194
|
+
mapping(bytes32 => bool) public usedCommitments;
|
|
195
|
+
|
|
196
|
+
// Step 1: Commit to trade
|
|
197
|
+
function commitTrade(bytes32 commitment) public {
|
|
198
|
+
usedCommitments[commitment] = true;
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
// Step 2: Reveal trade (next block)
|
|
202
|
+
function revealTrade(
|
|
203
|
+
uint256 amount,
|
|
204
|
+
uint256 minOutput,
|
|
205
|
+
bytes32 secret
|
|
206
|
+
) public {
|
|
207
|
+
bytes32 commitment = keccak256(abi.encodePacked(
|
|
208
|
+
msg.sender, amount, minOutput, secret
|
|
209
|
+
));
|
|
210
|
+
require(usedCommitments[commitment], "Invalid commitment");
|
|
211
|
+
// Perform swap
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
```
|
|
215
|
+
|
|
216
|
+
## Security Best Practices
|
|
217
|
+
|
|
218
|
+
### Checks-Effects-Interactions Pattern
|
|
219
|
+
|
|
220
|
+
```solidity
|
|
221
|
+
contract SecurePattern {
|
|
222
|
+
mapping(address => uint256) public balances;
|
|
223
|
+
|
|
224
|
+
function withdraw(uint256 amount) public {
|
|
225
|
+
// 1. CHECKS: Validate conditions
|
|
226
|
+
require(amount <= balances[msg.sender], "Insufficient balance");
|
|
227
|
+
require(amount > 0, "Amount must be positive");
|
|
228
|
+
|
|
229
|
+
// 2. EFFECTS: Update state
|
|
230
|
+
balances[msg.sender] -= amount;
|
|
231
|
+
|
|
232
|
+
// 3. INTERACTIONS: External calls last
|
|
233
|
+
(bool success, ) = msg.sender.call{value: amount}("");
|
|
234
|
+
require(success, "Transfer failed");
|
|
235
|
+
}
|
|
236
|
+
}
|
|
237
|
+
```
|
|
238
|
+
|
|
239
|
+
### Pull Over Push Pattern
|
|
240
|
+
|
|
241
|
+
```solidity
|
|
242
|
+
// Prefer this (pull)
|
|
243
|
+
contract SecurePayment {
|
|
244
|
+
mapping(address => uint256) public pendingWithdrawals;
|
|
245
|
+
|
|
246
|
+
function recordPayment(address recipient, uint256 amount) internal {
|
|
247
|
+
pendingWithdrawals[recipient] += amount;
|
|
248
|
+
}
|
|
249
|
+
|
|
250
|
+
function withdraw() public {
|
|
251
|
+
uint256 amount = pendingWithdrawals[msg.sender];
|
|
252
|
+
require(amount > 0, "Nothing to withdraw");
|
|
253
|
+
|
|
254
|
+
pendingWithdrawals[msg.sender] = 0;
|
|
255
|
+
payable(msg.sender).transfer(amount);
|
|
256
|
+
}
|
|
257
|
+
}
|
|
258
|
+
|
|
259
|
+
// Over this (push)
|
|
260
|
+
contract RiskyPayment {
|
|
261
|
+
function distributePayments(address[] memory recipients, uint256[] memory amounts) public {
|
|
262
|
+
for (uint i = 0; i < recipients.length; i++) {
|
|
263
|
+
// If any transfer fails, entire batch fails
|
|
264
|
+
payable(recipients[i]).transfer(amounts[i]);
|
|
265
|
+
}
|
|
266
|
+
}
|
|
267
|
+
}
|
|
268
|
+
```
|
|
269
|
+
|
|
270
|
+
### Input Validation
|
|
271
|
+
|
|
272
|
+
```solidity
|
|
273
|
+
contract SecureContract {
|
|
274
|
+
function transfer(address to, uint256 amount) public {
|
|
275
|
+
// Validate inputs
|
|
276
|
+
require(to != address(0), "Invalid recipient");
|
|
277
|
+
require(to != address(this), "Cannot send to contract");
|
|
278
|
+
require(amount > 0, "Amount must be positive");
|
|
279
|
+
require(amount <= balances[msg.sender], "Insufficient balance");
|
|
280
|
+
|
|
281
|
+
// Proceed with transfer
|
|
282
|
+
balances[msg.sender] -= amount;
|
|
283
|
+
balances[to] += amount;
|
|
284
|
+
}
|
|
285
|
+
}
|
|
286
|
+
```
|
|
287
|
+
|
|
288
|
+
### Emergency Stop (Circuit Breaker)
|
|
289
|
+
|
|
290
|
+
```solidity
|
|
291
|
+
import "@openzeppelin/contracts/security/Pausable.sol";
|
|
292
|
+
|
|
293
|
+
contract EmergencyStop is Pausable, Ownable {
|
|
294
|
+
function criticalFunction() public whenNotPaused {
|
|
295
|
+
// Function logic
|
|
296
|
+
}
|
|
297
|
+
|
|
298
|
+
function emergencyStop() public onlyOwner {
|
|
299
|
+
_pause();
|
|
300
|
+
}
|
|
301
|
+
|
|
302
|
+
function resume() public onlyOwner {
|
|
303
|
+
_unpause();
|
|
304
|
+
}
|
|
305
|
+
}
|
|
306
|
+
```
|
|
307
|
+
|
|
308
|
+
## Gas Optimization
|
|
309
|
+
|
|
310
|
+
### Use `uint256` Instead of Smaller Types
|
|
311
|
+
|
|
312
|
+
```solidity
|
|
313
|
+
// More gas efficient
|
|
314
|
+
contract GasEfficient {
|
|
315
|
+
uint256 public value; // Optimal
|
|
316
|
+
|
|
317
|
+
function set(uint256 _value) public {
|
|
318
|
+
value = _value;
|
|
319
|
+
}
|
|
320
|
+
}
|
|
321
|
+
|
|
322
|
+
// Less efficient
|
|
323
|
+
contract GasInefficient {
|
|
324
|
+
uint8 public value; // Still uses 256-bit slot
|
|
325
|
+
|
|
326
|
+
function set(uint8 _value) public {
|
|
327
|
+
value = _value; // Extra gas for type conversion
|
|
328
|
+
}
|
|
329
|
+
}
|
|
330
|
+
```
|
|
331
|
+
|
|
332
|
+
### Pack Storage Variables
|
|
333
|
+
|
|
334
|
+
```solidity
|
|
335
|
+
// Gas efficient (3 variables in 1 slot)
|
|
336
|
+
contract PackedStorage {
|
|
337
|
+
uint128 public a; // Slot 0
|
|
338
|
+
uint64 public b; // Slot 0
|
|
339
|
+
uint64 public c; // Slot 0
|
|
340
|
+
uint256 public d; // Slot 1
|
|
341
|
+
}
|
|
342
|
+
|
|
343
|
+
// Gas inefficient (each variable in separate slot)
|
|
344
|
+
contract UnpackedStorage {
|
|
345
|
+
uint256 public a; // Slot 0
|
|
346
|
+
uint256 public b; // Slot 1
|
|
347
|
+
uint256 public c; // Slot 2
|
|
348
|
+
uint256 public d; // Slot 3
|
|
349
|
+
}
|
|
350
|
+
```
|
|
351
|
+
|
|
352
|
+
### Use `calldata` Instead of `memory` for Function Arguments
|
|
353
|
+
|
|
354
|
+
```solidity
|
|
355
|
+
contract GasOptimized {
|
|
356
|
+
// More gas efficient
|
|
357
|
+
function processData(uint256[] calldata data) public pure returns (uint256) {
|
|
358
|
+
return data[0];
|
|
359
|
+
}
|
|
360
|
+
|
|
361
|
+
// Less efficient
|
|
362
|
+
function processDataMemory(uint256[] memory data) public pure returns (uint256) {
|
|
363
|
+
return data[0];
|
|
364
|
+
}
|
|
365
|
+
}
|
|
366
|
+
```
|
|
367
|
+
|
|
368
|
+
### Use Events for Data Storage (When Appropriate)
|
|
369
|
+
|
|
370
|
+
```solidity
|
|
371
|
+
contract EventStorage {
|
|
372
|
+
// Emitting events is cheaper than storage
|
|
373
|
+
event DataStored(address indexed user, uint256 indexed id, bytes data);
|
|
374
|
+
|
|
375
|
+
function storeData(uint256 id, bytes calldata data) public {
|
|
376
|
+
emit DataStored(msg.sender, id, data);
|
|
377
|
+
// Don't store in contract storage unless needed
|
|
378
|
+
}
|
|
379
|
+
}
|
|
380
|
+
```
|
|
381
|
+
|
|
382
|
+
## Common Vulnerabilities Checklist
|
|
383
|
+
|
|
384
|
+
```solidity
|
|
385
|
+
// Security Checklist Contract
|
|
386
|
+
contract SecurityChecklist {
|
|
387
|
+
/**
|
|
388
|
+
* [ ] Reentrancy protection (ReentrancyGuard or CEI pattern)
|
|
389
|
+
* [ ] Integer overflow/underflow (Solidity 0.8+ or SafeMath)
|
|
390
|
+
* [ ] Access control (Ownable, roles, modifiers)
|
|
391
|
+
* [ ] Input validation (require statements)
|
|
392
|
+
* [ ] Front-running mitigation (commit-reveal if applicable)
|
|
393
|
+
* [ ] Gas optimization (packed storage, calldata)
|
|
394
|
+
* [ ] Emergency stop mechanism (Pausable)
|
|
395
|
+
* [ ] Pull over push pattern for payments
|
|
396
|
+
* [ ] No delegatecall to untrusted contracts
|
|
397
|
+
* [ ] No tx.origin for authentication (use msg.sender)
|
|
398
|
+
* [ ] Proper event emission
|
|
399
|
+
* [ ] External calls at end of function
|
|
400
|
+
* [ ] Check return values of external calls
|
|
401
|
+
* [ ] No hardcoded addresses
|
|
402
|
+
* [ ] Upgrade mechanism (if proxy pattern)
|
|
403
|
+
*/
|
|
404
|
+
}
|
|
405
|
+
```
|
|
406
|
+
|
|
407
|
+
## Testing for Security
|
|
408
|
+
|
|
409
|
+
```javascript
|
|
410
|
+
// Hardhat test example
|
|
411
|
+
const { expect } = require("chai");
|
|
412
|
+
const { ethers } = require("hardhat");
|
|
413
|
+
|
|
414
|
+
describe("Security Tests", function () {
|
|
415
|
+
it("Should prevent reentrancy attack", async function () {
|
|
416
|
+
const [attacker] = await ethers.getSigners();
|
|
417
|
+
|
|
418
|
+
const VictimBank = await ethers.getContractFactory("SecureBank");
|
|
419
|
+
const bank = await VictimBank.deploy();
|
|
420
|
+
|
|
421
|
+
const Attacker = await ethers.getContractFactory("ReentrancyAttacker");
|
|
422
|
+
const attackerContract = await Attacker.deploy(bank.address);
|
|
423
|
+
|
|
424
|
+
// Deposit funds
|
|
425
|
+
await bank.deposit({ value: ethers.utils.parseEther("10") });
|
|
426
|
+
|
|
427
|
+
// Attempt reentrancy attack
|
|
428
|
+
await expect(
|
|
429
|
+
attackerContract.attack({ value: ethers.utils.parseEther("1") }),
|
|
430
|
+
).to.be.revertedWith("ReentrancyGuard: reentrant call");
|
|
431
|
+
});
|
|
432
|
+
|
|
433
|
+
it("Should prevent integer overflow", async function () {
|
|
434
|
+
const Token = await ethers.getContractFactory("SecureToken");
|
|
435
|
+
const token = await Token.deploy();
|
|
436
|
+
|
|
437
|
+
// Attempt overflow
|
|
438
|
+
await expect(token.transfer(attacker.address, ethers.constants.MaxUint256))
|
|
439
|
+
.to.be.reverted;
|
|
440
|
+
});
|
|
441
|
+
|
|
442
|
+
it("Should enforce access control", async function () {
|
|
443
|
+
const [owner, attacker] = await ethers.getSigners();
|
|
444
|
+
|
|
445
|
+
const Contract = await ethers.getContractFactory("SecureContract");
|
|
446
|
+
const contract = await Contract.deploy();
|
|
447
|
+
|
|
448
|
+
// Attempt unauthorized withdrawal
|
|
449
|
+
await expect(contract.connect(attacker).withdraw(100)).to.be.revertedWith(
|
|
450
|
+
"Ownable: caller is not the owner",
|
|
451
|
+
);
|
|
452
|
+
});
|
|
453
|
+
});
|
|
454
|
+
```
|
|
455
|
+
|
|
456
|
+
## Audit Preparation
|
|
457
|
+
|
|
458
|
+
```solidity
|
|
459
|
+
contract WellDocumentedContract {
|
|
460
|
+
/**
|
|
461
|
+
* @title Well Documented Contract
|
|
462
|
+
* @dev Example of proper documentation for audits
|
|
463
|
+
* @notice This contract handles user deposits and withdrawals
|
|
464
|
+
*/
|
|
465
|
+
|
|
466
|
+
/// @notice Mapping of user balances
|
|
467
|
+
mapping(address => uint256) public balances;
|
|
468
|
+
|
|
469
|
+
/**
|
|
470
|
+
* @dev Deposits ETH into the contract
|
|
471
|
+
* @notice Anyone can deposit funds
|
|
472
|
+
*/
|
|
473
|
+
function deposit() public payable {
|
|
474
|
+
require(msg.value > 0, "Must send ETH");
|
|
475
|
+
balances[msg.sender] += msg.value;
|
|
476
|
+
}
|
|
477
|
+
|
|
478
|
+
/**
|
|
479
|
+
* @dev Withdraws user's balance
|
|
480
|
+
* @notice Follows CEI pattern to prevent reentrancy
|
|
481
|
+
* @param amount Amount to withdraw in wei
|
|
482
|
+
*/
|
|
483
|
+
function withdraw(uint256 amount) public {
|
|
484
|
+
// CHECKS
|
|
485
|
+
require(amount <= balances[msg.sender], "Insufficient balance");
|
|
486
|
+
|
|
487
|
+
// EFFECTS
|
|
488
|
+
balances[msg.sender] -= amount;
|
|
489
|
+
|
|
490
|
+
// INTERACTIONS
|
|
491
|
+
(bool success, ) = msg.sender.call{value: amount}("");
|
|
492
|
+
require(success, "Transfer failed");
|
|
493
|
+
}
|
|
494
|
+
}
|
|
495
|
+
```
|
|
496
|
+
|
|
497
|
+
## Resources
|
|
498
|
+
|
|
499
|
+
- **references/reentrancy.md**: Comprehensive reentrancy prevention
|
|
500
|
+
- **references/access-control.md**: Role-based access patterns
|
|
501
|
+
- **references/overflow-underflow.md**: SafeMath and integer safety
|
|
502
|
+
- **references/gas-optimization.md**: Gas saving techniques
|
|
503
|
+
- **references/vulnerability-patterns.md**: Common vulnerability catalog
|
|
504
|
+
- **assets/solidity-contracts-templates.sol**: Secure contract templates
|
|
505
|
+
- **assets/security-checklist.md**: Pre-audit checklist
|
|
506
|
+
- **scripts/analyze-contract.sh**: Static analysis tools
|
|
507
|
+
|
|
508
|
+
## Tools for Security Analysis
|
|
509
|
+
|
|
510
|
+
- **Slither**: Static analysis tool
|
|
511
|
+
- **Mythril**: Security analysis tool
|
|
512
|
+
- **Echidna**: Fuzzing tool
|
|
513
|
+
- **Manticore**: Symbolic execution
|
|
514
|
+
- **Securify**: Automated security scanner
|
|
515
|
+
|
|
516
|
+
## Common Pitfalls
|
|
517
|
+
|
|
518
|
+
1. **Using `tx.origin` for Authentication**: Use `msg.sender` instead
|
|
519
|
+
2. **Unchecked External Calls**: Always check return values
|
|
520
|
+
3. **Delegatecall to Untrusted Contracts**: Can hijack your contract
|
|
521
|
+
4. **Floating Pragma**: Pin to specific Solidity version
|
|
522
|
+
5. **Missing Events**: Emit events for state changes
|
|
523
|
+
6. **Excessive Gas in Loops**: Can hit block gas limit
|
|
524
|
+
7. **No Upgrade Path**: Consider proxy patterns if upgrades needed
|