compact-agent 1.10.1 → 1.11.1
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/bin/ecc-hooks.cjs +110 -0
- package/dist/config.js +9 -1
- package/dist/config.js.map +1 -1
- package/dist/ecc.d.ts +11 -0
- package/dist/ecc.js +142 -27
- package/dist/ecc.js.map +1 -1
- package/dist/index.js +47 -7
- package/dist/index.js.map +1 -1
- package/dist/query.js +26 -0
- package/dist/query.js.map +1 -1
- package/dist/theme.js +6 -2
- package/dist/theme.js.map +1 -1
- package/package.json +1 -1
- package/resources/ecc/agents/a11y-architect.md +149 -0
- package/resources/ecc/agents/architect.md +11 -3
- package/resources/ecc/agents/build-error-resolver.md +11 -4
- package/resources/ecc/agents/chief-of-staff.md +11 -4
- package/resources/ecc/agents/code-architect.md +80 -0
- package/resources/ecc/agents/code-explorer.md +78 -0
- package/resources/ecc/agents/code-reviewer.md +89 -4
- package/resources/ecc/agents/code-simplifier.md +56 -0
- package/resources/ecc/agents/comment-analyzer.md +54 -0
- package/resources/ecc/agents/conversation-analyzer.md +61 -0
- package/resources/ecc/agents/cpp-build-resolver.md +99 -0
- package/resources/ecc/agents/cpp-reviewer.md +81 -0
- package/resources/ecc/agents/csharp-reviewer.md +110 -0
- package/resources/ecc/agents/dart-build-resolver.md +210 -0
- package/resources/ecc/agents/database-reviewer.md +11 -3
- package/resources/ecc/agents/django-build-resolver.md +252 -0
- package/resources/ecc/agents/django-reviewer.md +169 -0
- package/resources/ecc/agents/doc-updater.md +11 -3
- package/resources/ecc/agents/docs-lookup.md +77 -0
- package/resources/ecc/agents/e2e-runner.md +11 -4
- package/resources/ecc/agents/fastapi-reviewer.md +79 -0
- package/resources/ecc/agents/flutter-reviewer.md +252 -0
- package/resources/ecc/agents/fsharp-reviewer.md +109 -0
- package/resources/ecc/agents/gan-evaluator.md +218 -0
- package/resources/ecc/agents/gan-generator.md +140 -0
- package/resources/ecc/agents/gan-planner.md +108 -0
- package/resources/ecc/agents/go-build-resolver.md +11 -4
- package/resources/ecc/agents/go-reviewer.md +11 -3
- package/resources/ecc/agents/harmonyos-app-resolver.md +182 -0
- package/resources/ecc/agents/harness-optimizer.md +12 -2
- package/resources/ecc/agents/healthcare-reviewer.md +92 -0
- package/resources/ecc/agents/homelab-architect.md +107 -0
- package/resources/ecc/agents/java-build-resolver.md +275 -0
- package/resources/ecc/agents/java-reviewer.md +190 -0
- package/resources/ecc/agents/kotlin-build-resolver.md +127 -0
- package/resources/ecc/agents/kotlin-reviewer.md +168 -0
- package/resources/ecc/agents/loop-operator.md +12 -3
- package/resources/ecc/agents/mle-reviewer.md +162 -0
- package/resources/ecc/agents/network-architect.md +106 -0
- package/resources/ecc/agents/network-config-reviewer.md +106 -0
- package/resources/ecc/agents/network-troubleshooter.md +128 -0
- package/resources/ecc/agents/opensource-forker.md +207 -0
- package/resources/ecc/agents/opensource-packager.md +258 -0
- package/resources/ecc/agents/opensource-sanitizer.md +197 -0
- package/resources/ecc/agents/performance-optimizer.md +455 -0
- package/resources/ecc/agents/planner.md +11 -2
- package/resources/ecc/agents/pr-test-analyzer.md +54 -0
- package/resources/ecc/agents/python-reviewer.md +11 -3
- package/resources/ecc/agents/pytorch-build-resolver.md +129 -0
- package/resources/ecc/agents/refactor-cleaner.md +11 -4
- package/resources/ecc/agents/rust-build-resolver.md +157 -0
- package/resources/ecc/agents/rust-reviewer.md +103 -0
- package/resources/ecc/agents/security-reviewer.md +11 -3
- package/resources/ecc/agents/seo-specialist.md +71 -0
- package/resources/ecc/agents/silent-failure-hunter.md +59 -0
- package/resources/ecc/agents/swift-build-resolver.md +170 -0
- package/resources/ecc/agents/swift-reviewer.md +116 -0
- package/resources/ecc/agents/tdd-guide.md +11 -4
- package/resources/ecc/agents/type-design-analyzer.md +50 -0
- package/resources/ecc/agents/typescript-reviewer.md +121 -0
- package/resources/ecc/commands/aside.md +164 -0
- package/resources/ecc/commands/auto-update.md +28 -0
- package/resources/ecc/commands/build-fix.md +66 -0
- package/resources/ecc/commands/checkpoint.md +78 -0
- package/resources/ecc/commands/code-review.md +289 -0
- package/resources/ecc/commands/cost-report.md +107 -0
- package/resources/ecc/commands/cpp-build.md +173 -0
- package/resources/ecc/commands/cpp-review.md +132 -0
- package/resources/ecc/commands/cpp-test.md +251 -0
- package/resources/ecc/commands/ecc-guide.md +93 -0
- package/resources/ecc/commands/evolve.md +178 -0
- package/resources/ecc/commands/fastapi-review.md +39 -0
- package/resources/ecc/commands/feature-dev.md +49 -0
- package/resources/ecc/commands/flutter-build.md +164 -0
- package/resources/ecc/commands/flutter-review.md +116 -0
- package/resources/ecc/commands/flutter-test.md +144 -0
- package/resources/ecc/commands/gan-build.md +103 -0
- package/resources/ecc/commands/gan-design.md +39 -0
- package/resources/ecc/commands/go-build.md +183 -0
- package/resources/ecc/commands/go-review.md +148 -0
- package/resources/ecc/commands/go-test.md +268 -0
- package/resources/ecc/commands/gradle-build.md +70 -0
- package/resources/ecc/commands/harness-audit.md +77 -0
- package/resources/ecc/commands/hookify-configure.md +14 -0
- package/resources/ecc/commands/hookify-help.md +46 -0
- package/resources/ecc/commands/hookify-list.md +21 -0
- package/resources/ecc/commands/hookify.md +50 -0
- package/resources/ecc/commands/instinct-export.md +66 -0
- package/resources/ecc/commands/instinct-import.md +114 -0
- package/resources/ecc/commands/instinct-status.md +59 -0
- package/resources/ecc/commands/jira.md +106 -0
- package/resources/ecc/commands/kotlin-build.md +174 -0
- package/resources/ecc/commands/kotlin-review.md +140 -0
- package/resources/ecc/commands/kotlin-test.md +312 -0
- package/resources/ecc/commands/learn-eval.md +116 -0
- package/resources/ecc/commands/learn.md +74 -0
- package/resources/ecc/commands/loop-start.md +36 -0
- package/resources/ecc/commands/loop-status.md +77 -0
- package/resources/ecc/commands/model-route.md +30 -0
- package/resources/ecc/commands/multi-backend.md +162 -0
- package/resources/ecc/commands/multi-execute.md +319 -0
- package/resources/ecc/commands/multi-frontend.md +162 -0
- package/resources/ecc/commands/multi-plan.md +272 -0
- package/resources/ecc/commands/multi-workflow.md +195 -0
- package/resources/ecc/commands/plan-prd.md +160 -0
- package/resources/ecc/commands/plan.md +200 -0
- package/resources/ecc/commands/pm2.md +276 -0
- package/resources/ecc/commands/pr.md +184 -0
- package/resources/ecc/commands/project-init.md +86 -0
- package/resources/ecc/commands/projects.md +39 -0
- package/resources/ecc/commands/promote.md +41 -0
- package/resources/ecc/commands/prp-commit.md +112 -0
- package/resources/ecc/commands/prp-implement.md +385 -0
- package/resources/ecc/commands/prp-plan.md +502 -0
- package/resources/ecc/commands/prp-pr.md +184 -0
- package/resources/ecc/commands/prp-prd.md +447 -0
- package/resources/ecc/commands/prune.md +31 -0
- package/resources/ecc/commands/python-review.md +297 -0
- package/resources/ecc/commands/quality-gate.md +33 -0
- package/resources/ecc/commands/refactor-clean.md +84 -0
- package/resources/ecc/commands/resume-session.md +156 -0
- package/resources/ecc/commands/review-pr.md +37 -0
- package/resources/ecc/commands/rust-build.md +187 -0
- package/resources/ecc/commands/rust-review.md +142 -0
- package/resources/ecc/commands/rust-test.md +308 -0
- package/resources/ecc/commands/santa-loop.md +175 -0
- package/resources/ecc/commands/save-session.md +275 -0
- package/resources/ecc/commands/security-scan.md +92 -0
- package/resources/ecc/commands/sessions.md +339 -0
- package/resources/ecc/commands/setup-pm.md +80 -0
- package/resources/ecc/commands/skill-create.md +174 -0
- package/resources/ecc/commands/skill-health.md +54 -0
- package/resources/ecc/commands/test-coverage.md +73 -0
- package/resources/ecc/commands/update-codemaps.md +76 -0
- package/resources/ecc/commands/update-docs.md +88 -0
- package/resources/ecc/rules/README.md +120 -0
- package/resources/ecc/rules/angular/coding-style.md +182 -0
- package/resources/ecc/rules/angular/hooks.md +25 -0
- package/resources/ecc/rules/angular/patterns.md +249 -0
- package/resources/ecc/rules/angular/security.md +87 -0
- package/resources/ecc/rules/angular/testing.md +164 -0
- package/resources/ecc/rules/arkts/coding-style.md +153 -0
- package/resources/ecc/rules/arkts/hooks.md +135 -0
- package/resources/ecc/rules/arkts/patterns.md +236 -0
- package/resources/ecc/rules/arkts/security.md +141 -0
- package/resources/ecc/rules/arkts/testing.md +126 -0
- package/resources/ecc/rules/{common-agents.md → common/agents.md} +2 -4
- package/resources/ecc/rules/common/code-review.md +124 -0
- package/resources/ecc/rules/{common-coding-style.md → common/coding-style.md} +42 -4
- package/resources/ecc/rules/common/development-workflow.md +44 -0
- package/resources/ecc/rules/{common-git-workflow.md → common/git-workflow.md} +1 -5
- package/resources/ecc/rules/{common-hooks.md → common/hooks.md} +0 -4
- package/resources/ecc/rules/{common-patterns.md → common/patterns.md} +0 -4
- package/resources/ecc/rules/{common-performance.md → common/performance.md} +0 -4
- package/resources/ecc/rules/{common-security.md → common/security.md} +0 -4
- package/resources/ecc/rules/{common-testing.md → common/testing.md} +28 -4
- package/resources/ecc/rules/cpp/coding-style.md +44 -0
- package/resources/ecc/rules/cpp/hooks.md +39 -0
- package/resources/ecc/rules/cpp/patterns.md +51 -0
- package/resources/ecc/rules/cpp/security.md +51 -0
- package/resources/ecc/rules/cpp/testing.md +44 -0
- package/resources/ecc/rules/csharp/coding-style.md +72 -0
- package/resources/ecc/rules/csharp/hooks.md +25 -0
- package/resources/ecc/rules/csharp/patterns.md +50 -0
- package/resources/ecc/rules/csharp/security.md +58 -0
- package/resources/ecc/rules/csharp/testing.md +46 -0
- package/resources/ecc/rules/dart/coding-style.md +159 -0
- package/resources/ecc/rules/dart/hooks.md +66 -0
- package/resources/ecc/rules/dart/patterns.md +261 -0
- package/resources/ecc/rules/dart/security.md +135 -0
- package/resources/ecc/rules/dart/testing.md +215 -0
- package/resources/ecc/rules/fsharp/coding-style.md +112 -0
- package/resources/ecc/rules/fsharp/hooks.md +26 -0
- package/resources/ecc/rules/fsharp/patterns.md +111 -0
- package/resources/ecc/rules/fsharp/security.md +76 -0
- package/resources/ecc/rules/fsharp/testing.md +62 -0
- package/resources/ecc/rules/{golang-coding-style.md → golang/coding-style.md} +6 -5
- package/resources/ecc/rules/{golang-hooks.md → golang/hooks.md} +5 -4
- package/resources/ecc/rules/{golang-patterns.md → golang/patterns.md} +5 -4
- package/resources/ecc/rules/{golang-security.md → golang/security.md} +5 -4
- package/resources/ecc/rules/{golang-testing.md → golang/testing.md} +5 -4
- package/resources/ecc/rules/java/coding-style.md +114 -0
- package/resources/ecc/rules/java/hooks.md +18 -0
- package/resources/ecc/rules/java/patterns.md +147 -0
- package/resources/ecc/rules/java/security.md +101 -0
- package/resources/ecc/rules/java/testing.md +133 -0
- package/resources/ecc/rules/kotlin/coding-style.md +86 -0
- package/resources/ecc/rules/{kotlin-hooks.md → kotlin/hooks.md} +5 -4
- package/resources/ecc/rules/kotlin/patterns.md +146 -0
- package/resources/ecc/rules/kotlin/security.md +82 -0
- package/resources/ecc/rules/kotlin/testing.md +128 -0
- package/resources/ecc/rules/perl/coding-style.md +46 -0
- package/resources/ecc/rules/perl/hooks.md +22 -0
- package/resources/ecc/rules/perl/patterns.md +76 -0
- package/resources/ecc/rules/perl/security.md +69 -0
- package/resources/ecc/rules/perl/testing.md +54 -0
- package/resources/ecc/rules/php/coding-style.md +40 -0
- package/resources/ecc/rules/{php-hooks.md → php/hooks.md} +7 -4
- package/resources/ecc/rules/php/patterns.md +33 -0
- package/resources/ecc/rules/php/security.md +37 -0
- package/resources/ecc/rules/php/testing.md +39 -0
- package/resources/ecc/rules/{python-coding-style.md → python/coding-style.md} +4 -4
- package/resources/ecc/rules/python/fastapi.md +58 -0
- package/resources/ecc/rules/{python-hooks.md → python/hooks.md} +4 -4
- package/resources/ecc/rules/{python-patterns.md → python/patterns.md} +4 -4
- package/resources/ecc/rules/{python-security.md → python/security.md} +4 -4
- package/resources/ecc/rules/{python-testing.md → python/testing.md} +4 -4
- package/resources/ecc/rules/ruby/coding-style.md +46 -0
- package/resources/ecc/rules/ruby/hooks.md +37 -0
- package/resources/ecc/rules/ruby/patterns.md +44 -0
- package/resources/ecc/rules/ruby/security.md +51 -0
- package/resources/ecc/rules/ruby/testing.md +51 -0
- package/resources/ecc/rules/rust/coding-style.md +151 -0
- package/resources/ecc/rules/rust/hooks.md +16 -0
- package/resources/ecc/rules/rust/patterns.md +168 -0
- package/resources/ecc/rules/rust/security.md +141 -0
- package/resources/ecc/rules/rust/testing.md +154 -0
- package/resources/ecc/rules/{swift-coding-style.md → swift/coding-style.md} +6 -6
- package/resources/ecc/rules/swift/hooks.md +20 -0
- package/resources/ecc/rules/{swift-patterns.md → swift/patterns.md} +5 -5
- package/resources/ecc/rules/{swift-security.md → swift/security.md} +7 -7
- package/resources/ecc/rules/{swift-testing.md → swift/testing.md} +5 -5
- package/resources/ecc/rules/typescript/coding-style.md +199 -0
- package/resources/ecc/rules/{typescript-hooks.md → typescript/hooks.md} +6 -4
- package/resources/ecc/rules/{typescript-patterns.md → typescript/patterns.md} +6 -4
- package/resources/ecc/rules/{typescript-security.md → typescript/security.md} +6 -4
- package/resources/ecc/rules/typescript/testing.md +18 -0
- package/resources/ecc/rules/web/coding-style.md +96 -0
- package/resources/ecc/rules/web/design-quality.md +63 -0
- package/resources/ecc/rules/web/hooks.md +129 -0
- package/resources/ecc/rules/web/patterns.md +79 -0
- package/resources/ecc/rules/web/performance.md +64 -0
- package/resources/ecc/rules/web/security.md +57 -0
- package/resources/ecc/rules/web/testing.md +55 -0
- package/resources/ecc/rules/zh/README.md +108 -0
- package/resources/ecc/rules/zh/agents.md +50 -0
- package/resources/ecc/rules/zh/code-review.md +124 -0
- package/resources/ecc/rules/zh/coding-style.md +48 -0
- package/resources/ecc/rules/zh/development-workflow.md +44 -0
- package/resources/ecc/rules/zh/git-workflow.md +24 -0
- package/resources/ecc/rules/zh/hooks.md +30 -0
- package/resources/ecc/rules/zh/patterns.md +31 -0
- package/resources/ecc/rules/zh/performance.md +55 -0
- package/resources/ecc/rules/zh/security.md +29 -0
- package/resources/ecc/rules/zh/testing.md +29 -0
- package/resources/ecc/skills/accessibility/SKILL.md +146 -0
- package/resources/ecc/skills/agent-architecture-audit/SKILL.md +256 -0
- package/resources/ecc/skills/agent-eval/SKILL.md +145 -0
- package/resources/ecc/skills/agent-harness-construction/SKILL.md +73 -0
- package/resources/ecc/skills/agent-introspection-debugging/SKILL.md +1 -0
- package/resources/ecc/skills/agent-payment-x402/SKILL.md +224 -0
- package/resources/ecc/skills/agent-sort/SKILL.md +1 -0
- package/resources/ecc/skills/agentic-engineering/SKILL.md +63 -0
- package/resources/ecc/skills/agentic-os/SKILL.md +387 -0
- package/resources/ecc/skills/ai-first-engineering/SKILL.md +51 -0
- package/resources/ecc/skills/ai-regression-testing/SKILL.md +385 -0
- package/resources/ecc/skills/android-clean-architecture/SKILL.md +339 -0
- package/resources/ecc/skills/angular-developer/SKILL.md +154 -0
- package/resources/ecc/skills/angular-developer/references/angular-animations.md +160 -0
- package/resources/ecc/skills/angular-developer/references/angular-aria.md +410 -0
- package/resources/ecc/skills/angular-developer/references/cli.md +86 -0
- package/resources/ecc/skills/angular-developer/references/component-harnesses.md +59 -0
- package/resources/ecc/skills/angular-developer/references/component-styling.md +91 -0
- package/resources/ecc/skills/angular-developer/references/components.md +117 -0
- package/resources/ecc/skills/angular-developer/references/creating-services.md +97 -0
- package/resources/ecc/skills/angular-developer/references/data-resolvers.md +69 -0
- package/resources/ecc/skills/angular-developer/references/define-routes.md +67 -0
- package/resources/ecc/skills/angular-developer/references/defining-providers.md +72 -0
- package/resources/ecc/skills/angular-developer/references/di-fundamentals.md +120 -0
- package/resources/ecc/skills/angular-developer/references/e2e-testing.md +56 -0
- package/resources/ecc/skills/angular-developer/references/effects.md +83 -0
- package/resources/ecc/skills/angular-developer/references/hierarchical-injectors.md +43 -0
- package/resources/ecc/skills/angular-developer/references/host-elements.md +80 -0
- package/resources/ecc/skills/angular-developer/references/injection-context.md +63 -0
- package/resources/ecc/skills/angular-developer/references/inputs.md +101 -0
- package/resources/ecc/skills/angular-developer/references/linked-signal.md +59 -0
- package/resources/ecc/skills/angular-developer/references/loading-strategies.md +61 -0
- package/resources/ecc/skills/angular-developer/references/mcp.md +108 -0
- package/resources/ecc/skills/angular-developer/references/navigate-to-routes.md +69 -0
- package/resources/ecc/skills/angular-developer/references/outputs.md +86 -0
- package/resources/ecc/skills/angular-developer/references/reactive-forms.md +122 -0
- package/resources/ecc/skills/angular-developer/references/rendering-strategies.md +44 -0
- package/resources/ecc/skills/angular-developer/references/resource.md +77 -0
- package/resources/ecc/skills/angular-developer/references/route-animations.md +56 -0
- package/resources/ecc/skills/angular-developer/references/route-guards.md +52 -0
- package/resources/ecc/skills/angular-developer/references/router-lifecycle.md +45 -0
- package/resources/ecc/skills/angular-developer/references/router-testing.md +87 -0
- package/resources/ecc/skills/angular-developer/references/show-routes-with-outlets.md +68 -0
- package/resources/ecc/skills/angular-developer/references/signal-forms.md +795 -0
- package/resources/ecc/skills/angular-developer/references/signals-overview.md +94 -0
- package/resources/ecc/skills/angular-developer/references/tailwind-css.md +69 -0
- package/resources/ecc/skills/angular-developer/references/template-driven-forms.md +114 -0
- package/resources/ecc/skills/angular-developer/references/testing-fundamentals.md +65 -0
- package/resources/ecc/skills/api-connector-builder/SKILL.md +120 -0
- package/resources/ecc/skills/api-design/SKILL.md +1 -0
- package/resources/ecc/skills/architecture-decision-records/SKILL.md +179 -0
- package/resources/ecc/skills/article-writing/SKILL.md +1 -0
- package/resources/ecc/skills/automation-audit-ops/SKILL.md +142 -0
- package/resources/ecc/skills/autonomous-agent-harness/SKILL.md +273 -0
- package/resources/ecc/skills/autonomous-loops/SKILL.md +610 -0
- package/resources/ecc/skills/backend-patterns/SKILL.md +8 -44
- package/resources/ecc/skills/benchmark/SKILL.md +93 -0
- package/resources/ecc/skills/blueprint/SKILL.md +105 -0
- package/resources/ecc/skills/brand-voice/SKILL.md +1 -0
- package/resources/ecc/skills/browser-qa/SKILL.md +87 -0
- package/resources/ecc/skills/bun-runtime/SKILL.md +1 -0
- package/resources/ecc/skills/canary-watch/SKILL.md +99 -0
- package/resources/ecc/skills/carrier-relationship-management/SKILL.md +212 -0
- package/resources/ecc/skills/cisco-ios-patterns/SKILL.md +163 -0
- package/resources/ecc/skills/ck/SKILL.md +147 -0
- package/resources/ecc/skills/ck/commands/forget.mjs +44 -0
- package/resources/ecc/skills/ck/commands/info.mjs +24 -0
- package/resources/ecc/skills/ck/commands/init.mjs +143 -0
- package/resources/ecc/skills/ck/commands/list.mjs +40 -0
- package/resources/ecc/skills/ck/commands/migrate.mjs +202 -0
- package/resources/ecc/skills/ck/commands/resume.mjs +36 -0
- package/resources/ecc/skills/ck/commands/save.mjs +210 -0
- package/resources/ecc/skills/ck/commands/shared.mjs +387 -0
- package/resources/ecc/skills/ck/hooks/session-start.mjs +224 -0
- package/resources/ecc/skills/claude-devfleet/SKILL.md +103 -0
- package/resources/ecc/skills/click-path-audit/SKILL.md +244 -0
- package/resources/ecc/skills/clickhouse-io/SKILL.md +439 -0
- package/resources/ecc/skills/code-tour/SKILL.md +236 -0
- package/resources/ecc/skills/codebase-onboarding/SKILL.md +233 -0
- package/resources/ecc/skills/coding-standards/SKILL.md +1 -0
- package/resources/ecc/skills/compose-multiplatform-patterns/SKILL.md +299 -0
- package/resources/ecc/skills/configure-ecc/SKILL.md +384 -0
- package/resources/ecc/skills/connections-optimizer/SKILL.md +189 -0
- package/resources/ecc/skills/content-engine/SKILL.md +1 -0
- package/resources/ecc/skills/content-hash-cache-pattern/SKILL.md +161 -0
- package/resources/ecc/skills/context-budget/SKILL.md +135 -0
- package/resources/ecc/skills/continuous-agent-loop/SKILL.md +45 -0
- package/resources/ecc/skills/continuous-learning/SKILL.md +131 -0
- package/resources/ecc/skills/continuous-learning/config.json +18 -0
- package/resources/ecc/skills/continuous-learning/evaluate-session.sh +69 -0
- package/resources/ecc/skills/continuous-learning-v2/SKILL.md +360 -0
- package/resources/ecc/skills/continuous-learning-v2/agents/observer-loop.sh +322 -0
- package/resources/ecc/skills/continuous-learning-v2/agents/observer.md +198 -0
- package/resources/ecc/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
- package/resources/ecc/skills/continuous-learning-v2/agents/start-observer.sh +248 -0
- package/resources/ecc/skills/continuous-learning-v2/config.json +8 -0
- package/resources/ecc/skills/continuous-learning-v2/hooks/observe.sh +476 -0
- package/resources/ecc/skills/continuous-learning-v2/scripts/detect-project.sh +288 -0
- package/resources/ecc/skills/continuous-learning-v2/scripts/instinct-cli.py +1519 -0
- package/resources/ecc/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +31 -0
- package/resources/ecc/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +62 -0
- package/resources/ecc/skills/continuous-learning-v2/scripts/test_parse_instinct.py +1018 -0
- package/resources/ecc/skills/cost-aware-llm-pipeline/SKILL.md +183 -0
- package/resources/ecc/skills/cost-tracking/SKILL.md +147 -0
- package/resources/ecc/skills/council/SKILL.md +203 -0
- package/resources/ecc/skills/cpp-coding-standards/SKILL.md +723 -0
- package/resources/ecc/skills/cpp-testing/SKILL.md +324 -0
- package/resources/ecc/skills/crosspost/SKILL.md +1 -0
- package/resources/ecc/skills/csharp-testing/SKILL.md +321 -0
- package/resources/ecc/skills/customer-billing-ops/SKILL.md +140 -0
- package/resources/ecc/skills/customs-trade-compliance/SKILL.md +263 -0
- package/resources/ecc/skills/dart-flutter-patterns/SKILL.md +563 -0
- package/resources/ecc/skills/dashboard-builder/SKILL.md +108 -0
- package/resources/ecc/skills/data-scraper-agent/SKILL.md +764 -0
- package/resources/ecc/skills/database-migrations/SKILL.md +429 -0
- package/resources/ecc/skills/deep-research/SKILL.md +5 -0
- package/resources/ecc/skills/defi-amm-security/SKILL.md +166 -0
- package/resources/ecc/skills/deployment-patterns/SKILL.md +427 -0
- package/resources/ecc/skills/design-system/SKILL.md +82 -0
- package/resources/ecc/skills/django-celery/SKILL.md +457 -0
- package/resources/ecc/skills/django-patterns/SKILL.md +734 -0
- package/resources/ecc/skills/django-security/SKILL.md +593 -0
- package/resources/ecc/skills/django-tdd/SKILL.md +729 -0
- package/resources/ecc/skills/django-verification/SKILL.md +469 -0
- package/resources/ecc/skills/dmux-workflows/SKILL.md +52 -4
- package/resources/ecc/skills/docker-patterns/SKILL.md +364 -0
- package/resources/ecc/skills/documentation-lookup/SKILL.md +1 -0
- package/resources/ecc/skills/dotnet-patterns/SKILL.md +321 -0
- package/resources/ecc/skills/e2e-testing/SKILL.md +1 -0
- package/resources/ecc/skills/ecc-guide/SKILL.md +189 -0
- package/resources/ecc/skills/ecc-tools-cost-audit/SKILL.md +160 -0
- package/resources/ecc/skills/email-ops/SKILL.md +121 -0
- package/resources/ecc/skills/energy-procurement/SKILL.md +228 -0
- package/resources/ecc/skills/enterprise-agent-ops/SKILL.md +50 -0
- package/resources/ecc/skills/error-handling/SKILL.md +376 -0
- package/resources/ecc/skills/eval-harness/SKILL.md +36 -1
- package/resources/ecc/skills/evm-token-decimals/SKILL.md +130 -0
- package/resources/ecc/skills/exa-search/SKILL.md +18 -80
- package/resources/ecc/skills/fal-ai-media/SKILL.md +32 -20
- package/resources/ecc/skills/fastapi-patterns/SKILL.md +327 -0
- package/resources/ecc/skills/finance-billing-ops/SKILL.md +127 -0
- package/resources/ecc/skills/flox-environments/SKILL.md +496 -0
- package/resources/ecc/skills/flutter-dart-code-review/SKILL.md +435 -0
- package/resources/ecc/skills/foundation-models-on-device/SKILL.md +243 -0
- package/resources/ecc/skills/frontend-design-direction/SKILL.md +92 -0
- package/resources/ecc/skills/frontend-patterns/SKILL.md +1 -6
- package/resources/ecc/skills/frontend-slides/SKILL.md +2 -1
- package/resources/ecc/skills/frontend-slides/animation-patterns.md +122 -0
- package/resources/ecc/skills/frontend-slides/html-template.md +419 -0
- package/resources/ecc/skills/frontend-slides/scripts/export-pdf.sh +418 -0
- package/resources/ecc/skills/frontend-slides/scripts/extract-pptx.py +96 -0
- package/resources/ecc/skills/frontend-slides/viewport-base.css +153 -0
- package/resources/ecc/skills/fsharp-testing/SKILL.md +280 -0
- package/resources/ecc/skills/gan-style-harness/SKILL.md +278 -0
- package/resources/ecc/skills/gateguard/SKILL.md +125 -0
- package/resources/ecc/skills/git-workflow/SKILL.md +715 -0
- package/resources/ecc/skills/github-ops/SKILL.md +144 -0
- package/resources/ecc/skills/golang-patterns/SKILL.md +674 -0
- package/resources/ecc/skills/golang-testing/SKILL.md +720 -0
- package/resources/ecc/skills/google-workspace-ops/SKILL.md +95 -0
- package/resources/ecc/skills/healthcare-cdss-patterns/SKILL.md +245 -0
- package/resources/ecc/skills/healthcare-emr-patterns/SKILL.md +159 -0
- package/resources/ecc/skills/healthcare-eval-harness/SKILL.md +207 -0
- package/resources/ecc/skills/healthcare-phi-compliance/SKILL.md +145 -0
- package/resources/ecc/skills/hermes-imports/SKILL.md +88 -0
- package/resources/ecc/skills/hexagonal-architecture/SKILL.md +276 -0
- package/resources/ecc/skills/hipaa-compliance/SKILL.md +78 -0
- package/resources/ecc/skills/homelab-network-readiness/SKILL.md +169 -0
- package/resources/ecc/skills/homelab-network-setup/SKILL.md +129 -0
- package/resources/ecc/skills/homelab-pihole-dns/SKILL.md +274 -0
- package/resources/ecc/skills/homelab-vlan-segmentation/SKILL.md +311 -0
- package/resources/ecc/skills/homelab-wireguard-vpn/SKILL.md +305 -0
- package/resources/ecc/skills/hookify-rules/SKILL.md +128 -0
- package/resources/ecc/skills/inventory-demand-planning/SKILL.md +247 -0
- package/resources/ecc/skills/investor-materials/SKILL.md +1 -0
- package/resources/ecc/skills/investor-outreach/SKILL.md +1 -0
- package/resources/ecc/skills/ios-icon-gen/SKILL.md +157 -0
- package/resources/ecc/skills/ios-icon-gen/scripts/generate_icons.swift +258 -0
- package/resources/ecc/skills/ios-icon-gen/scripts/iconify_gen.sh +235 -0
- package/resources/ecc/skills/iterative-retrieval/SKILL.md +211 -0
- package/resources/ecc/skills/java-coding-standards/SKILL.md +383 -0
- package/resources/ecc/skills/jira-integration/SKILL.md +293 -0
- package/resources/ecc/skills/jpa-patterns/SKILL.md +151 -0
- package/resources/ecc/skills/knowledge-ops/SKILL.md +154 -0
- package/resources/ecc/skills/kotlin-coroutines-flows/SKILL.md +284 -0
- package/resources/ecc/skills/kotlin-exposed-patterns/SKILL.md +719 -0
- package/resources/ecc/skills/kotlin-ktor-patterns/SKILL.md +689 -0
- package/resources/ecc/skills/kotlin-patterns/SKILL.md +711 -0
- package/resources/ecc/skills/kotlin-testing/SKILL.md +824 -0
- package/resources/ecc/skills/laravel-patterns/SKILL.md +415 -0
- package/resources/ecc/skills/laravel-plugin-discovery/SKILL.md +229 -0
- package/resources/ecc/skills/laravel-security/SKILL.md +285 -0
- package/resources/ecc/skills/laravel-tdd/SKILL.md +283 -0
- package/resources/ecc/skills/laravel-verification/SKILL.md +179 -0
- package/resources/ecc/skills/lead-intelligence/SKILL.md +321 -0
- package/resources/ecc/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
- package/resources/ecc/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
- package/resources/ecc/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
- package/resources/ecc/skills/lead-intelligence/agents/signal-scorer.md +60 -0
- package/resources/ecc/skills/liquid-glass-design/SKILL.md +279 -0
- package/resources/ecc/skills/llm-trading-agent-security/SKILL.md +146 -0
- package/resources/ecc/skills/logistics-exception-management/SKILL.md +222 -0
- package/resources/ecc/skills/make-interfaces-feel-better/SKILL.md +151 -0
- package/resources/ecc/skills/manim-video/SKILL.md +89 -0
- package/resources/ecc/skills/manim-video/assets/network_graph_scene.py +52 -0
- package/resources/ecc/skills/market-research/SKILL.md +1 -0
- package/resources/ecc/skills/mcp-server-patterns/SKILL.md +3 -0
- package/resources/ecc/skills/messages-ops/SKILL.md +104 -0
- package/resources/ecc/skills/mle-workflow/SKILL.md +1 -1
- package/resources/ecc/skills/motion-advanced/SKILL.md +596 -0
- package/resources/ecc/skills/motion-foundations/SKILL.md +299 -0
- package/resources/ecc/skills/motion-patterns/SKILL.md +435 -0
- package/resources/ecc/skills/motion-ui/SKILL.md +575 -0
- package/resources/ecc/skills/mysql-patterns/SKILL.md +412 -0
- package/resources/ecc/skills/nanoclaw-repl/SKILL.md +33 -0
- package/resources/ecc/skills/nestjs-patterns/SKILL.md +230 -0
- package/resources/ecc/skills/netmiko-ssh-automation/SKILL.md +173 -0
- package/resources/ecc/skills/network-bgp-diagnostics/SKILL.md +167 -0
- package/resources/ecc/skills/network-config-validation/SKILL.md +210 -0
- package/resources/ecc/skills/network-interface-health/SKILL.md +152 -0
- package/resources/ecc/skills/nextjs-turbopack/SKILL.md +1 -0
- package/resources/ecc/skills/nodejs-keccak256/SKILL.md +102 -0
- package/resources/ecc/skills/nutrient-document-processing/SKILL.md +167 -0
- package/resources/ecc/skills/nuxt4-patterns/SKILL.md +100 -0
- package/resources/ecc/skills/openclaw-persona-forge/SKILL.md +288 -0
- package/resources/ecc/skills/openclaw-persona-forge/gacha.py +224 -0
- package/resources/ecc/skills/openclaw-persona-forge/gacha.sh +5 -0
- package/resources/ecc/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
- package/resources/ecc/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
- package/resources/ecc/skills/openclaw-persona-forge/references/error-handling.md +53 -0
- package/resources/ecc/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
- package/resources/ecc/skills/openclaw-persona-forge/references/naming-system.md +39 -0
- package/resources/ecc/skills/openclaw-persona-forge/references/output-template.md +166 -0
- package/resources/ecc/skills/opensource-pipeline/SKILL.md +255 -0
- package/resources/ecc/skills/perl-patterns/SKILL.md +504 -0
- package/resources/ecc/skills/perl-security/SKILL.md +503 -0
- package/resources/ecc/skills/perl-testing/SKILL.md +475 -0
- package/resources/ecc/skills/plan-orchestrate/SKILL.md +262 -0
- package/resources/ecc/skills/plankton-code-quality/SKILL.md +236 -0
- package/resources/ecc/skills/postgres-patterns/SKILL.md +147 -0
- package/resources/ecc/skills/product-capability/SKILL.md +1 -0
- package/resources/ecc/skills/product-lens/SKILL.md +92 -0
- package/resources/ecc/skills/production-audit/SKILL.md +206 -0
- package/resources/ecc/skills/production-scheduling/SKILL.md +238 -0
- package/resources/ecc/skills/project-flow-ops/SKILL.md +111 -0
- package/resources/ecc/skills/prompt-optimizer/SKILL.md +398 -0
- package/resources/ecc/skills/python-patterns/SKILL.md +750 -0
- package/resources/ecc/skills/python-testing/SKILL.md +816 -0
- package/resources/ecc/skills/pytorch-patterns/SKILL.md +396 -0
- package/resources/ecc/skills/quality-nonconformance/SKILL.md +260 -0
- package/resources/ecc/skills/quarkus-patterns/SKILL.md +722 -0
- package/resources/ecc/skills/quarkus-security/SKILL.md +467 -0
- package/resources/ecc/skills/quarkus-tdd/SKILL.md +811 -0
- package/resources/ecc/skills/quarkus-verification/SKILL.md +479 -0
- package/resources/ecc/skills/ralphinho-rfc-pipeline/SKILL.md +67 -0
- package/resources/ecc/skills/redis-patterns/SKILL.md +403 -0
- package/resources/ecc/skills/regex-vs-llm-structured-text/SKILL.md +220 -0
- package/resources/ecc/skills/remotion-video-creation/SKILL.md +43 -0
- package/resources/ecc/skills/remotion-video-creation/rules/3d.md +86 -0
- package/resources/ecc/skills/remotion-video-creation/rules/animations.md +29 -0
- package/resources/ecc/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
- package/resources/ecc/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
- package/resources/ecc/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
- package/resources/ecc/skills/remotion-video-creation/rules/assets.md +78 -0
- package/resources/ecc/skills/remotion-video-creation/rules/audio.md +172 -0
- package/resources/ecc/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
- package/resources/ecc/skills/remotion-video-creation/rules/can-decode.md +75 -0
- package/resources/ecc/skills/remotion-video-creation/rules/charts.md +58 -0
- package/resources/ecc/skills/remotion-video-creation/rules/compositions.md +146 -0
- package/resources/ecc/skills/remotion-video-creation/rules/display-captions.md +126 -0
- package/resources/ecc/skills/remotion-video-creation/rules/extract-frames.md +229 -0
- package/resources/ecc/skills/remotion-video-creation/rules/fonts.md +152 -0
- package/resources/ecc/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
- package/resources/ecc/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
- package/resources/ecc/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
- package/resources/ecc/skills/remotion-video-creation/rules/gifs.md +138 -0
- package/resources/ecc/skills/remotion-video-creation/rules/images.md +130 -0
- package/resources/ecc/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
- package/resources/ecc/skills/remotion-video-creation/rules/lottie.md +67 -0
- package/resources/ecc/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
- package/resources/ecc/skills/remotion-video-creation/rules/measuring-text.md +143 -0
- package/resources/ecc/skills/remotion-video-creation/rules/sequencing.md +106 -0
- package/resources/ecc/skills/remotion-video-creation/rules/tailwind.md +11 -0
- package/resources/ecc/skills/remotion-video-creation/rules/text-animations.md +20 -0
- package/resources/ecc/skills/remotion-video-creation/rules/timing.md +179 -0
- package/resources/ecc/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
- package/resources/ecc/skills/remotion-video-creation/rules/transitions.md +122 -0
- package/resources/ecc/skills/remotion-video-creation/rules/trimming.md +52 -0
- package/resources/ecc/skills/remotion-video-creation/rules/videos.md +171 -0
- package/resources/ecc/skills/repo-scan/SKILL.md +78 -0
- package/resources/ecc/skills/research-ops/SKILL.md +112 -0
- package/resources/ecc/skills/returns-reverse-logistics/SKILL.md +240 -0
- package/resources/ecc/skills/rules-distill/SKILL.md +264 -0
- package/resources/ecc/skills/rules-distill/scripts/scan-rules.sh +58 -0
- package/resources/ecc/skills/rules-distill/scripts/scan-skills.sh +129 -0
- package/resources/ecc/skills/rust-patterns/SKILL.md +499 -0
- package/resources/ecc/skills/rust-testing/SKILL.md +500 -0
- package/resources/ecc/skills/safety-guard/SKILL.md +75 -0
- package/resources/ecc/skills/santa-method/SKILL.md +306 -0
- package/resources/ecc/skills/scientific-db-pubmed-database/SKILL.md +175 -0
- package/resources/ecc/skills/scientific-db-uspto-database/SKILL.md +177 -0
- package/resources/ecc/skills/scientific-pkg-gget/SKILL.md +166 -0
- package/resources/ecc/skills/scientific-thinking-literature-review/SKILL.md +192 -0
- package/resources/ecc/skills/scientific-thinking-scholar-evaluation/SKILL.md +160 -0
- package/resources/ecc/skills/search-first/SKILL.md +182 -0
- package/resources/ecc/skills/security-bounty-hunter/SKILL.md +99 -0
- package/resources/ecc/skills/security-review/SKILL.md +11 -2
- package/resources/ecc/skills/security-review/cloud-infrastructure-security.md +361 -0
- package/resources/ecc/skills/security-scan/SKILL.md +165 -0
- package/resources/ecc/skills/seo/SKILL.md +154 -0
- package/resources/ecc/skills/skill-comply/SKILL.md +58 -0
- package/resources/ecc/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
- package/resources/ecc/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
- package/resources/ecc/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
- package/resources/ecc/skills/skill-comply/prompts/classifier.md +24 -0
- package/resources/ecc/skills/skill-comply/prompts/scenario_generator.md +62 -0
- package/resources/ecc/skills/skill-comply/prompts/spec_generator.md +42 -0
- package/resources/ecc/skills/skill-comply/pyproject.toml +15 -0
- package/resources/ecc/skills/skill-comply/scripts/__init__.py +0 -0
- package/resources/ecc/skills/skill-comply/scripts/classifier.py +85 -0
- package/resources/ecc/skills/skill-comply/scripts/grader.py +124 -0
- package/resources/ecc/skills/skill-comply/scripts/parser.py +107 -0
- package/resources/ecc/skills/skill-comply/scripts/report.py +170 -0
- package/resources/ecc/skills/skill-comply/scripts/run.py +127 -0
- package/resources/ecc/skills/skill-comply/scripts/runner.py +186 -0
- package/resources/ecc/skills/skill-comply/scripts/scenario_generator.py +70 -0
- package/resources/ecc/skills/skill-comply/scripts/spec_generator.py +72 -0
- package/resources/ecc/skills/skill-comply/scripts/utils.py +13 -0
- package/resources/ecc/skills/skill-comply/tests/test_grader.py +197 -0
- package/resources/ecc/skills/skill-comply/tests/test_parser.py +90 -0
- package/resources/ecc/skills/skill-comply/tests/test_runner.py +172 -0
- package/resources/ecc/skills/skill-scout/SKILL.md +140 -0
- package/resources/ecc/skills/skill-stocktake/SKILL.md +194 -0
- package/resources/ecc/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
- package/resources/ecc/skills/skill-stocktake/scripts/save-results.sh +56 -0
- package/resources/ecc/skills/skill-stocktake/scripts/scan.sh +170 -0
- package/resources/ecc/skills/social-graph-ranker/SKILL.md +154 -0
- package/resources/ecc/skills/springboot-patterns/SKILL.md +314 -0
- package/resources/ecc/skills/springboot-security/SKILL.md +272 -0
- package/resources/ecc/skills/springboot-tdd/SKILL.md +158 -0
- package/resources/ecc/skills/springboot-verification/SKILL.md +231 -0
- package/resources/ecc/skills/strategic-compact/SKILL.md +31 -2
- package/resources/ecc/skills/strategic-compact/suggest-compact.sh +54 -0
- package/resources/ecc/skills/swift-actor-persistence/SKILL.md +143 -0
- package/resources/ecc/skills/swift-concurrency-6-2/SKILL.md +216 -0
- package/resources/ecc/skills/swift-protocol-di-testing/SKILL.md +190 -0
- package/resources/ecc/skills/swiftui-patterns/SKILL.md +259 -0
- package/resources/ecc/skills/tdd-workflow/SKILL.md +54 -0
- package/resources/ecc/skills/team-builder/SKILL.md +168 -0
- package/resources/ecc/skills/terminal-ops/SKILL.md +109 -0
- package/resources/ecc/skills/tinystruct-patterns/SKILL.md +131 -0
- package/resources/ecc/skills/tinystruct-patterns/references/architecture.md +77 -0
- package/resources/ecc/skills/tinystruct-patterns/references/data-handling.md +35 -0
- package/resources/ecc/skills/tinystruct-patterns/references/routing.md +57 -0
- package/resources/ecc/skills/tinystruct-patterns/references/system-usage.md +74 -0
- package/resources/ecc/skills/tinystruct-patterns/references/testing.md +59 -0
- package/resources/ecc/skills/token-budget-advisor/SKILL.md +133 -0
- package/resources/ecc/skills/ui-demo/SKILL.md +465 -0
- package/resources/ecc/skills/ui-to-vue/SKILL.md +134 -0
- package/resources/ecc/skills/unified-notifications-ops/SKILL.md +187 -0
- package/resources/ecc/skills/verification-loop/SKILL.md +1 -0
- package/resources/ecc/skills/video-editing/SKILL.md +4 -1
- package/resources/ecc/skills/videodb/SKILL.md +374 -0
- package/resources/ecc/skills/videodb/reference/api-reference.md +550 -0
- package/resources/ecc/skills/videodb/reference/capture-reference.md +407 -0
- package/resources/ecc/skills/videodb/reference/capture.md +101 -0
- package/resources/ecc/skills/videodb/reference/editor.md +443 -0
- package/resources/ecc/skills/videodb/reference/generative.md +331 -0
- package/resources/ecc/skills/videodb/reference/rtstream-reference.md +564 -0
- package/resources/ecc/skills/videodb/reference/rtstream.md +65 -0
- package/resources/ecc/skills/videodb/reference/search.md +230 -0
- package/resources/ecc/skills/videodb/reference/streaming.md +406 -0
- package/resources/ecc/skills/videodb/reference/use-cases.md +118 -0
- package/resources/ecc/skills/videodb/scripts/ws_listener.py +282 -0
- package/resources/ecc/skills/visa-doc-translate/README.md +86 -0
- package/resources/ecc/skills/visa-doc-translate/SKILL.md +117 -0
- package/resources/ecc/skills/vite-patterns/SKILL.md +449 -0
- package/resources/ecc/skills/windows-desktop-e2e/SKILL.md +788 -0
- package/resources/ecc/skills/workspace-surface-audit/SKILL.md +125 -0
- package/resources/ecc/skills/x-api/SKILL.md +5 -0
- package/resources/ecc/agents/architect.json +0 -16
- package/resources/ecc/agents/build-error-resolver.json +0 -17
- package/resources/ecc/agents/chief-of-staff.json +0 -17
- package/resources/ecc/agents/code-reviewer.json +0 -16
- package/resources/ecc/agents/database-reviewer.json +0 -16
- package/resources/ecc/agents/doc-updater.json +0 -16
- package/resources/ecc/agents/e2e-runner.json +0 -17
- package/resources/ecc/agents/go-build-resolver.json +0 -17
- package/resources/ecc/agents/go-reviewer.json +0 -16
- package/resources/ecc/agents/harness-optimizer.json +0 -15
- package/resources/ecc/agents/loop-operator.json +0 -16
- package/resources/ecc/agents/planner.json +0 -15
- package/resources/ecc/agents/python-reviewer.json +0 -16
- package/resources/ecc/agents/refactor-cleaner.json +0 -17
- package/resources/ecc/agents/security-reviewer.json +0 -16
- package/resources/ecc/agents/tdd-guide.json +0 -17
- package/resources/ecc/commands/add-language-rules.md +0 -39
- package/resources/ecc/commands/database-migration.md +0 -36
- package/resources/ecc/commands/feature-development.md +0 -38
- package/resources/ecc/rules/common-development-workflow.md +0 -33
- package/resources/ecc/rules/kotlin-coding-style.md +0 -39
- package/resources/ecc/rules/kotlin-patterns.md +0 -50
- package/resources/ecc/rules/kotlin-security.md +0 -58
- package/resources/ecc/rules/kotlin-testing.md +0 -38
- package/resources/ecc/rules/php-coding-style.md +0 -25
- package/resources/ecc/rules/php-patterns.md +0 -23
- package/resources/ecc/rules/php-security.md +0 -24
- package/resources/ecc/rules/php-testing.md +0 -26
- package/resources/ecc/rules/swift-hooks.md +0 -20
- package/resources/ecc/rules/typescript-coding-style.md +0 -63
- package/resources/ecc/rules/typescript-testing.md +0 -16
- package/resources/ecc/skills/agent-introspection-debugging/agents/openai.yaml +0 -7
- package/resources/ecc/skills/agent-sort/agents/openai.yaml +0 -7
- package/resources/ecc/skills/api-design/agents/openai.yaml +0 -7
- package/resources/ecc/skills/article-writing/agents/openai.yaml +0 -7
- package/resources/ecc/skills/backend-patterns/agents/openai.yaml +0 -7
- package/resources/ecc/skills/brand-voice/agents/openai.yaml +0 -7
- package/resources/ecc/skills/bun-runtime/agents/openai.yaml +0 -7
- package/resources/ecc/skills/coding-standards/agents/openai.yaml +0 -7
- package/resources/ecc/skills/content-engine/agents/openai.yaml +0 -7
- package/resources/ecc/skills/crosspost/agents/openai.yaml +0 -7
- package/resources/ecc/skills/deep-research/agents/openai.yaml +0 -7
- package/resources/ecc/skills/dmux-workflows/agents/openai.yaml +0 -7
- package/resources/ecc/skills/documentation-lookup/agents/openai.yaml +0 -7
- package/resources/ecc/skills/e2e-testing/agents/openai.yaml +0 -7
- package/resources/ecc/skills/eval-harness/agents/openai.yaml +0 -7
- package/resources/ecc/skills/everything-claude-code/SKILL.md +0 -442
- package/resources/ecc/skills/everything-claude-code/agents/openai.yaml +0 -7
- package/resources/ecc/skills/exa-search/agents/openai.yaml +0 -7
- package/resources/ecc/skills/fal-ai-media/agents/openai.yaml +0 -7
- package/resources/ecc/skills/frontend-patterns/agents/openai.yaml +0 -7
- package/resources/ecc/skills/frontend-slides/agents/openai.yaml +0 -7
- package/resources/ecc/skills/investor-materials/agents/openai.yaml +0 -7
- package/resources/ecc/skills/investor-outreach/agents/openai.yaml +0 -7
- package/resources/ecc/skills/market-research/agents/openai.yaml +0 -7
- package/resources/ecc/skills/mcp-server-patterns/agents/openai.yaml +0 -7
- package/resources/ecc/skills/mle-workflow/agents/openai.yaml +0 -7
- package/resources/ecc/skills/nextjs-turbopack/agents/openai.yaml +0 -7
- package/resources/ecc/skills/product-capability/agents/openai.yaml +0 -7
- package/resources/ecc/skills/security-review/agents/openai.yaml +0 -7
- package/resources/ecc/skills/strategic-compact/agents/openai.yaml +0 -7
- package/resources/ecc/skills/tdd-workflow/agents/openai.yaml +0 -7
- package/resources/ecc/skills/verification-loop/agents/openai.yaml +0 -7
- package/resources/ecc/skills/video-editing/agents/openai.yaml +0 -7
- package/resources/ecc/skills/x-api/agents/openai.yaml +0 -7
|
@@ -0,0 +1,429 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: database-migrations
|
|
3
|
+
description: Database migration best practices for schema changes, data migrations, rollbacks, and zero-downtime deployments across PostgreSQL, MySQL, and common ORMs (Prisma, Drizzle, Kysely, Django, TypeORM, golang-migrate).
|
|
4
|
+
origin: ECC
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Database Migration Patterns
|
|
8
|
+
|
|
9
|
+
Safe, reversible database schema changes for production systems.
|
|
10
|
+
|
|
11
|
+
## When to Activate
|
|
12
|
+
|
|
13
|
+
- Creating or altering database tables
|
|
14
|
+
- Adding/removing columns or indexes
|
|
15
|
+
- Running data migrations (backfill, transform)
|
|
16
|
+
- Planning zero-downtime schema changes
|
|
17
|
+
- Setting up migration tooling for a new project
|
|
18
|
+
|
|
19
|
+
## Core Principles
|
|
20
|
+
|
|
21
|
+
1. **Every change is a migration** — never alter production databases manually
|
|
22
|
+
2. **Migrations are forward-only in production** — rollbacks use new forward migrations
|
|
23
|
+
3. **Schema and data migrations are separate** — never mix DDL and DML in one migration
|
|
24
|
+
4. **Test migrations against production-sized data** — a migration that works on 100 rows may lock on 10M
|
|
25
|
+
5. **Migrations are immutable once deployed** — never edit a migration that has run in production
|
|
26
|
+
|
|
27
|
+
## Migration Safety Checklist
|
|
28
|
+
|
|
29
|
+
Before applying any migration:
|
|
30
|
+
|
|
31
|
+
- [ ] Migration has both UP and DOWN (or is explicitly marked irreversible)
|
|
32
|
+
- [ ] No full table locks on large tables (use concurrent operations)
|
|
33
|
+
- [ ] New columns have defaults or are nullable (never add NOT NULL without default)
|
|
34
|
+
- [ ] Indexes created concurrently (not inline with CREATE TABLE for existing tables)
|
|
35
|
+
- [ ] Data backfill is a separate migration from schema change
|
|
36
|
+
- [ ] Tested against a copy of production data
|
|
37
|
+
- [ ] Rollback plan documented
|
|
38
|
+
|
|
39
|
+
## PostgreSQL Patterns
|
|
40
|
+
|
|
41
|
+
### Adding a Column Safely
|
|
42
|
+
|
|
43
|
+
```sql
|
|
44
|
+
-- GOOD: Nullable column, no lock
|
|
45
|
+
ALTER TABLE users ADD COLUMN avatar_url TEXT;
|
|
46
|
+
|
|
47
|
+
-- GOOD: Column with default (Postgres 11+ is instant, no rewrite)
|
|
48
|
+
ALTER TABLE users ADD COLUMN is_active BOOLEAN NOT NULL DEFAULT true;
|
|
49
|
+
|
|
50
|
+
-- BAD: NOT NULL without default on existing table (requires full rewrite)
|
|
51
|
+
ALTER TABLE users ADD COLUMN role TEXT NOT NULL;
|
|
52
|
+
-- This locks the table and rewrites every row
|
|
53
|
+
```
|
|
54
|
+
|
|
55
|
+
### Adding an Index Without Downtime
|
|
56
|
+
|
|
57
|
+
```sql
|
|
58
|
+
-- BAD: Blocks writes on large tables
|
|
59
|
+
CREATE INDEX idx_users_email ON users (email);
|
|
60
|
+
|
|
61
|
+
-- GOOD: Non-blocking, allows concurrent writes
|
|
62
|
+
CREATE INDEX CONCURRENTLY idx_users_email ON users (email);
|
|
63
|
+
|
|
64
|
+
-- Note: CONCURRENTLY cannot run inside a transaction block
|
|
65
|
+
-- Most migration tools need special handling for this
|
|
66
|
+
```
|
|
67
|
+
|
|
68
|
+
### Renaming a Column (Zero-Downtime)
|
|
69
|
+
|
|
70
|
+
Never rename directly in production. Use the expand-contract pattern:
|
|
71
|
+
|
|
72
|
+
```sql
|
|
73
|
+
-- Step 1: Add new column (migration 001)
|
|
74
|
+
ALTER TABLE users ADD COLUMN display_name TEXT;
|
|
75
|
+
|
|
76
|
+
-- Step 2: Backfill data (migration 002, data migration)
|
|
77
|
+
UPDATE users SET display_name = username WHERE display_name IS NULL;
|
|
78
|
+
|
|
79
|
+
-- Step 3: Update application code to read/write both columns
|
|
80
|
+
-- Deploy application changes
|
|
81
|
+
|
|
82
|
+
-- Step 4: Stop writing to old column, drop it (migration 003)
|
|
83
|
+
ALTER TABLE users DROP COLUMN username;
|
|
84
|
+
```
|
|
85
|
+
|
|
86
|
+
### Removing a Column Safely
|
|
87
|
+
|
|
88
|
+
```sql
|
|
89
|
+
-- Step 1: Remove all application references to the column
|
|
90
|
+
-- Step 2: Deploy application without the column reference
|
|
91
|
+
-- Step 3: Drop column in next migration
|
|
92
|
+
ALTER TABLE orders DROP COLUMN legacy_status;
|
|
93
|
+
|
|
94
|
+
-- For Django: use SeparateDatabaseAndState to remove from model
|
|
95
|
+
-- without generating DROP COLUMN (then drop in next migration)
|
|
96
|
+
```
|
|
97
|
+
|
|
98
|
+
### Large Data Migrations
|
|
99
|
+
|
|
100
|
+
```sql
|
|
101
|
+
-- BAD: Updates all rows in one transaction (locks table)
|
|
102
|
+
UPDATE users SET normalized_email = LOWER(email);
|
|
103
|
+
|
|
104
|
+
-- GOOD: Batch update with progress
|
|
105
|
+
DO $$
|
|
106
|
+
DECLARE
|
|
107
|
+
batch_size INT := 10000;
|
|
108
|
+
rows_updated INT;
|
|
109
|
+
BEGIN
|
|
110
|
+
LOOP
|
|
111
|
+
UPDATE users
|
|
112
|
+
SET normalized_email = LOWER(email)
|
|
113
|
+
WHERE id IN (
|
|
114
|
+
SELECT id FROM users
|
|
115
|
+
WHERE normalized_email IS NULL
|
|
116
|
+
LIMIT batch_size
|
|
117
|
+
FOR UPDATE SKIP LOCKED
|
|
118
|
+
);
|
|
119
|
+
GET DIAGNOSTICS rows_updated = ROW_COUNT;
|
|
120
|
+
RAISE NOTICE 'Updated % rows', rows_updated;
|
|
121
|
+
EXIT WHEN rows_updated = 0;
|
|
122
|
+
COMMIT;
|
|
123
|
+
END LOOP;
|
|
124
|
+
END $$;
|
|
125
|
+
```
|
|
126
|
+
|
|
127
|
+
## Prisma (TypeScript/Node.js)
|
|
128
|
+
|
|
129
|
+
### Workflow
|
|
130
|
+
|
|
131
|
+
```bash
|
|
132
|
+
# Create migration from schema changes
|
|
133
|
+
npx prisma migrate dev --name add_user_avatar
|
|
134
|
+
|
|
135
|
+
# Apply pending migrations in production
|
|
136
|
+
npx prisma migrate deploy
|
|
137
|
+
|
|
138
|
+
# Reset database (dev only)
|
|
139
|
+
npx prisma migrate reset
|
|
140
|
+
|
|
141
|
+
# Generate client after schema changes
|
|
142
|
+
npx prisma generate
|
|
143
|
+
```
|
|
144
|
+
|
|
145
|
+
### Schema Example
|
|
146
|
+
|
|
147
|
+
```prisma
|
|
148
|
+
model User {
|
|
149
|
+
id String @id @default(cuid())
|
|
150
|
+
email String @unique
|
|
151
|
+
name String?
|
|
152
|
+
avatarUrl String? @map("avatar_url")
|
|
153
|
+
createdAt DateTime @default(now()) @map("created_at")
|
|
154
|
+
updatedAt DateTime @updatedAt @map("updated_at")
|
|
155
|
+
orders Order[]
|
|
156
|
+
|
|
157
|
+
@@map("users")
|
|
158
|
+
@@index([email])
|
|
159
|
+
}
|
|
160
|
+
```
|
|
161
|
+
|
|
162
|
+
### Custom SQL Migration
|
|
163
|
+
|
|
164
|
+
For operations Prisma cannot express (concurrent indexes, data backfills):
|
|
165
|
+
|
|
166
|
+
```bash
|
|
167
|
+
# Create empty migration, then edit the SQL manually
|
|
168
|
+
npx prisma migrate dev --create-only --name add_email_index
|
|
169
|
+
```
|
|
170
|
+
|
|
171
|
+
```sql
|
|
172
|
+
-- migrations/20240115_add_email_index/migration.sql
|
|
173
|
+
-- Prisma cannot generate CONCURRENTLY, so we write it manually
|
|
174
|
+
CREATE INDEX CONCURRENTLY IF NOT EXISTS idx_users_email ON users (email);
|
|
175
|
+
```
|
|
176
|
+
|
|
177
|
+
## Drizzle (TypeScript/Node.js)
|
|
178
|
+
|
|
179
|
+
### Workflow
|
|
180
|
+
|
|
181
|
+
```bash
|
|
182
|
+
# Generate migration from schema changes
|
|
183
|
+
npx drizzle-kit generate
|
|
184
|
+
|
|
185
|
+
# Apply migrations
|
|
186
|
+
npx drizzle-kit migrate
|
|
187
|
+
|
|
188
|
+
# Push schema directly (dev only, no migration file)
|
|
189
|
+
npx drizzle-kit push
|
|
190
|
+
```
|
|
191
|
+
|
|
192
|
+
### Schema Example
|
|
193
|
+
|
|
194
|
+
```typescript
|
|
195
|
+
import { pgTable, text, timestamp, uuid, boolean } from "drizzle-orm/pg-core";
|
|
196
|
+
|
|
197
|
+
export const users = pgTable("users", {
|
|
198
|
+
id: uuid("id").primaryKey().defaultRandom(),
|
|
199
|
+
email: text("email").notNull().unique(),
|
|
200
|
+
name: text("name"),
|
|
201
|
+
isActive: boolean("is_active").notNull().default(true),
|
|
202
|
+
createdAt: timestamp("created_at").notNull().defaultNow(),
|
|
203
|
+
updatedAt: timestamp("updated_at").notNull().defaultNow(),
|
|
204
|
+
});
|
|
205
|
+
```
|
|
206
|
+
|
|
207
|
+
## Kysely (TypeScript/Node.js)
|
|
208
|
+
|
|
209
|
+
### Workflow (kysely-ctl)
|
|
210
|
+
|
|
211
|
+
```bash
|
|
212
|
+
# Initialize config file (kysely.config.ts)
|
|
213
|
+
kysely init
|
|
214
|
+
|
|
215
|
+
# Create a new migration file
|
|
216
|
+
kysely migrate make add_user_avatar
|
|
217
|
+
|
|
218
|
+
# Apply all pending migrations
|
|
219
|
+
kysely migrate latest
|
|
220
|
+
|
|
221
|
+
# Rollback last migration
|
|
222
|
+
kysely migrate down
|
|
223
|
+
|
|
224
|
+
# Show migration status
|
|
225
|
+
kysely migrate list
|
|
226
|
+
```
|
|
227
|
+
|
|
228
|
+
### Migration File
|
|
229
|
+
|
|
230
|
+
```typescript
|
|
231
|
+
// migrations/2024_01_15_001_create_user_profile.ts
|
|
232
|
+
import { type Kysely, sql } from 'kysely'
|
|
233
|
+
|
|
234
|
+
// IMPORTANT: Always use Kysely<any>, not your typed DB interface.
|
|
235
|
+
// Migrations are frozen in time and must not depend on current schema types.
|
|
236
|
+
export async function up(db: Kysely<any>): Promise<void> {
|
|
237
|
+
await db.schema
|
|
238
|
+
.createTable('user_profile')
|
|
239
|
+
.addColumn('id', 'serial', (col) => col.primaryKey())
|
|
240
|
+
.addColumn('email', 'varchar(255)', (col) => col.notNull().unique())
|
|
241
|
+
.addColumn('avatar_url', 'text')
|
|
242
|
+
.addColumn('created_at', 'timestamp', (col) =>
|
|
243
|
+
col.defaultTo(sql`now()`).notNull()
|
|
244
|
+
)
|
|
245
|
+
.execute()
|
|
246
|
+
|
|
247
|
+
await db.schema
|
|
248
|
+
.createIndex('idx_user_profile_avatar')
|
|
249
|
+
.on('user_profile')
|
|
250
|
+
.column('avatar_url')
|
|
251
|
+
.execute()
|
|
252
|
+
}
|
|
253
|
+
|
|
254
|
+
export async function down(db: Kysely<any>): Promise<void> {
|
|
255
|
+
await db.schema.dropTable('user_profile').execute()
|
|
256
|
+
}
|
|
257
|
+
```
|
|
258
|
+
|
|
259
|
+
### Programmatic Migrator
|
|
260
|
+
|
|
261
|
+
```typescript
|
|
262
|
+
import { Migrator, FileMigrationProvider } from 'kysely'
|
|
263
|
+
import { promises as fs } from 'fs'
|
|
264
|
+
import * as path from 'path'
|
|
265
|
+
// ESM only — CJS can use __dirname directly
|
|
266
|
+
import { fileURLToPath } from 'url'
|
|
267
|
+
const migrationFolder = path.join(
|
|
268
|
+
path.dirname(fileURLToPath(import.meta.url)),
|
|
269
|
+
'./migrations',
|
|
270
|
+
)
|
|
271
|
+
|
|
272
|
+
// `db` is your Kysely<any> database instance
|
|
273
|
+
const migrator = new Migrator({
|
|
274
|
+
db,
|
|
275
|
+
provider: new FileMigrationProvider({
|
|
276
|
+
fs,
|
|
277
|
+
path,
|
|
278
|
+
migrationFolder,
|
|
279
|
+
}),
|
|
280
|
+
// WARNING: Only enable in development. Disables timestamp-ordering
|
|
281
|
+
// validation, which can cause schema drift between environments.
|
|
282
|
+
// allowUnorderedMigrations: true,
|
|
283
|
+
})
|
|
284
|
+
|
|
285
|
+
const { error, results } = await migrator.migrateToLatest()
|
|
286
|
+
|
|
287
|
+
results?.forEach((it) => {
|
|
288
|
+
if (it.status === 'Success') {
|
|
289
|
+
console.log(`migration "${it.migrationName}" executed successfully`)
|
|
290
|
+
} else if (it.status === 'Error') {
|
|
291
|
+
console.error(`failed to execute migration "${it.migrationName}"`)
|
|
292
|
+
}
|
|
293
|
+
})
|
|
294
|
+
|
|
295
|
+
if (error) {
|
|
296
|
+
console.error('migration failed', error)
|
|
297
|
+
process.exit(1)
|
|
298
|
+
}
|
|
299
|
+
```
|
|
300
|
+
|
|
301
|
+
## Django (Python)
|
|
302
|
+
|
|
303
|
+
### Workflow
|
|
304
|
+
|
|
305
|
+
```bash
|
|
306
|
+
# Generate migration from model changes
|
|
307
|
+
python manage.py makemigrations
|
|
308
|
+
|
|
309
|
+
# Apply migrations
|
|
310
|
+
python manage.py migrate
|
|
311
|
+
|
|
312
|
+
# Show migration status
|
|
313
|
+
python manage.py showmigrations
|
|
314
|
+
|
|
315
|
+
# Generate empty migration for custom SQL
|
|
316
|
+
python manage.py makemigrations --empty app_name -n description
|
|
317
|
+
```
|
|
318
|
+
|
|
319
|
+
### Data Migration
|
|
320
|
+
|
|
321
|
+
```python
|
|
322
|
+
from django.db import migrations
|
|
323
|
+
|
|
324
|
+
def backfill_display_names(apps, schema_editor):
|
|
325
|
+
User = apps.get_model("accounts", "User")
|
|
326
|
+
batch_size = 5000
|
|
327
|
+
users = User.objects.filter(display_name="")
|
|
328
|
+
while users.exists():
|
|
329
|
+
batch = list(users[:batch_size])
|
|
330
|
+
for user in batch:
|
|
331
|
+
user.display_name = user.username
|
|
332
|
+
User.objects.bulk_update(batch, ["display_name"], batch_size=batch_size)
|
|
333
|
+
|
|
334
|
+
def reverse_backfill(apps, schema_editor):
|
|
335
|
+
pass # Data migration, no reverse needed
|
|
336
|
+
|
|
337
|
+
class Migration(migrations.Migration):
|
|
338
|
+
dependencies = [("accounts", "0015_add_display_name")]
|
|
339
|
+
|
|
340
|
+
operations = [
|
|
341
|
+
migrations.RunPython(backfill_display_names, reverse_backfill),
|
|
342
|
+
]
|
|
343
|
+
```
|
|
344
|
+
|
|
345
|
+
### SeparateDatabaseAndState
|
|
346
|
+
|
|
347
|
+
Remove a column from the Django model without dropping it from the database immediately:
|
|
348
|
+
|
|
349
|
+
```python
|
|
350
|
+
class Migration(migrations.Migration):
|
|
351
|
+
operations = [
|
|
352
|
+
migrations.SeparateDatabaseAndState(
|
|
353
|
+
state_operations=[
|
|
354
|
+
migrations.RemoveField(model_name="user", name="legacy_field"),
|
|
355
|
+
],
|
|
356
|
+
database_operations=[], # Don't touch the DB yet
|
|
357
|
+
),
|
|
358
|
+
]
|
|
359
|
+
```
|
|
360
|
+
|
|
361
|
+
## golang-migrate (Go)
|
|
362
|
+
|
|
363
|
+
### Workflow
|
|
364
|
+
|
|
365
|
+
```bash
|
|
366
|
+
# Create migration pair
|
|
367
|
+
migrate create -ext sql -dir migrations -seq add_user_avatar
|
|
368
|
+
|
|
369
|
+
# Apply all pending migrations
|
|
370
|
+
migrate -path migrations -database "$DATABASE_URL" up
|
|
371
|
+
|
|
372
|
+
# Rollback last migration
|
|
373
|
+
migrate -path migrations -database "$DATABASE_URL" down 1
|
|
374
|
+
|
|
375
|
+
# Force version (fix dirty state)
|
|
376
|
+
migrate -path migrations -database "$DATABASE_URL" force VERSION
|
|
377
|
+
```
|
|
378
|
+
|
|
379
|
+
### Migration Files
|
|
380
|
+
|
|
381
|
+
```sql
|
|
382
|
+
-- migrations/000003_add_user_avatar.up.sql
|
|
383
|
+
ALTER TABLE users ADD COLUMN avatar_url TEXT;
|
|
384
|
+
CREATE INDEX CONCURRENTLY idx_users_avatar ON users (avatar_url) WHERE avatar_url IS NOT NULL;
|
|
385
|
+
|
|
386
|
+
-- migrations/000003_add_user_avatar.down.sql
|
|
387
|
+
DROP INDEX IF EXISTS idx_users_avatar;
|
|
388
|
+
ALTER TABLE users DROP COLUMN IF EXISTS avatar_url;
|
|
389
|
+
```
|
|
390
|
+
|
|
391
|
+
## Zero-Downtime Migration Strategy
|
|
392
|
+
|
|
393
|
+
For critical production changes, follow the expand-contract pattern:
|
|
394
|
+
|
|
395
|
+
```
|
|
396
|
+
Phase 1: EXPAND
|
|
397
|
+
- Add new column/table (nullable or with default)
|
|
398
|
+
- Deploy: app writes to BOTH old and new
|
|
399
|
+
- Backfill existing data
|
|
400
|
+
|
|
401
|
+
Phase 2: MIGRATE
|
|
402
|
+
- Deploy: app reads from NEW, writes to BOTH
|
|
403
|
+
- Verify data consistency
|
|
404
|
+
|
|
405
|
+
Phase 3: CONTRACT
|
|
406
|
+
- Deploy: app only uses NEW
|
|
407
|
+
- Drop old column/table in separate migration
|
|
408
|
+
```
|
|
409
|
+
|
|
410
|
+
### Timeline Example
|
|
411
|
+
|
|
412
|
+
```
|
|
413
|
+
Day 1: Migration adds new_status column (nullable)
|
|
414
|
+
Day 1: Deploy app v2 — writes to both status and new_status
|
|
415
|
+
Day 2: Run backfill migration for existing rows
|
|
416
|
+
Day 3: Deploy app v3 — reads from new_status only
|
|
417
|
+
Day 7: Migration drops old status column
|
|
418
|
+
```
|
|
419
|
+
|
|
420
|
+
## Anti-Patterns
|
|
421
|
+
|
|
422
|
+
| Anti-Pattern | Why It Fails | Better Approach |
|
|
423
|
+
|-------------|-------------|-----------------|
|
|
424
|
+
| Manual SQL in production | No audit trail, unrepeatable | Always use migration files |
|
|
425
|
+
| Editing deployed migrations | Causes drift between environments | Create new migration instead |
|
|
426
|
+
| NOT NULL without default | Locks table, rewrites all rows | Add nullable, backfill, then add constraint |
|
|
427
|
+
| Inline index on large table | Blocks writes during build | CREATE INDEX CONCURRENTLY |
|
|
428
|
+
| Schema + data in one migration | Hard to rollback, long transactions | Separate migrations |
|
|
429
|
+
| Dropping column before removing code | Application errors on missing column | Remove code first, drop column next deploy |
|
|
@@ -1,10 +1,15 @@
|
|
|
1
1
|
---
|
|
2
2
|
name: deep-research
|
|
3
3
|
description: Multi-source deep research using firecrawl and exa MCPs. Searches the web, synthesizes findings, and delivers cited reports with source attribution. Use when the user wants thorough research on any topic with evidence and citations.
|
|
4
|
+
origin: ECC
|
|
4
5
|
---
|
|
5
6
|
|
|
6
7
|
# Deep Research
|
|
7
8
|
|
|
9
|
+
> **Drift-prone skill.** Firecrawl/Exa MCP tool names, quotas, and result
|
|
10
|
+
> shapes change. Verify the configured MCP tools and current API docs before
|
|
11
|
+
> promising coverage or quoting live source counts.
|
|
12
|
+
|
|
8
13
|
Produce thorough, cited research reports from multiple web sources using firecrawl and exa MCP tools.
|
|
9
14
|
|
|
10
15
|
## When to Activate
|
|
@@ -0,0 +1,166 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: defi-amm-security
|
|
3
|
+
description: Security checklist for Solidity AMM contracts, liquidity pools, and swap flows. Covers reentrancy, CEI ordering, donation or inflation attacks, oracle manipulation, slippage, admin controls, and integer math.
|
|
4
|
+
origin: ECC direct-port adaptation
|
|
5
|
+
version: "1.0.0"
|
|
6
|
+
---
|
|
7
|
+
|
|
8
|
+
# DeFi AMM Security
|
|
9
|
+
|
|
10
|
+
Critical vulnerability patterns and hardened implementations for Solidity AMM contracts, LP vaults, and swap functions.
|
|
11
|
+
|
|
12
|
+
## When to Use
|
|
13
|
+
|
|
14
|
+
- Writing or auditing a Solidity AMM or liquidity-pool contract
|
|
15
|
+
- Implementing swap, deposit, withdraw, mint, or burn flows that hold token balances
|
|
16
|
+
- Reviewing any contract that uses `token.balanceOf(address(this))` in share or reserve math
|
|
17
|
+
- Adding fee setters, pausers, oracle updates, or other admin functions to a DeFi protocol
|
|
18
|
+
|
|
19
|
+
## How It Works
|
|
20
|
+
|
|
21
|
+
Use this as a checklist-plus-pattern library. Review every user entrypoint against the categories below and prefer the hardened examples over hand-rolled variants.
|
|
22
|
+
|
|
23
|
+
## Execution Safety
|
|
24
|
+
|
|
25
|
+
The shell commands in this skill are local audit examples. Run them only in a trusted checkout or disposable sandbox, and do not splice untrusted contract names, paths, RPC URLs, private keys, or user-supplied flags into shell commands. Ask before installing tools or running long fuzzing/static-analysis jobs that may consume significant local or paid resources.
|
|
26
|
+
|
|
27
|
+
Never include secrets, private keys, seed phrases, API tokens, or mainnet signing credentials in command examples, logs, or reports.
|
|
28
|
+
|
|
29
|
+
## Examples
|
|
30
|
+
|
|
31
|
+
### Reentrancy: enforce CEI order
|
|
32
|
+
|
|
33
|
+
Vulnerable:
|
|
34
|
+
|
|
35
|
+
```solidity
|
|
36
|
+
function withdraw(uint256 amount) external {
|
|
37
|
+
require(balances[msg.sender] >= amount);
|
|
38
|
+
token.transfer(msg.sender, amount);
|
|
39
|
+
balances[msg.sender] -= amount;
|
|
40
|
+
}
|
|
41
|
+
```
|
|
42
|
+
|
|
43
|
+
Safe:
|
|
44
|
+
|
|
45
|
+
```solidity
|
|
46
|
+
import {ReentrancyGuard} from "@openzeppelin/contracts/utils/ReentrancyGuard.sol";
|
|
47
|
+
import {SafeERC20} from "@openzeppelin/contracts/token/ERC20/utils/SafeERC20.sol";
|
|
48
|
+
|
|
49
|
+
using SafeERC20 for IERC20;
|
|
50
|
+
|
|
51
|
+
function withdraw(uint256 amount) external nonReentrant {
|
|
52
|
+
require(balances[msg.sender] >= amount, "Insufficient");
|
|
53
|
+
balances[msg.sender] -= amount;
|
|
54
|
+
token.safeTransfer(msg.sender, amount);
|
|
55
|
+
}
|
|
56
|
+
```
|
|
57
|
+
|
|
58
|
+
Do not write your own guard when a hardened library exists.
|
|
59
|
+
|
|
60
|
+
### Donation or inflation attacks
|
|
61
|
+
|
|
62
|
+
Using `token.balanceOf(address(this))` directly for share math lets attackers manipulate the denominator by sending tokens to the contract outside the intended path.
|
|
63
|
+
|
|
64
|
+
```solidity
|
|
65
|
+
// Vulnerable
|
|
66
|
+
function deposit(uint256 assets) external returns (uint256 shares) {
|
|
67
|
+
shares = (assets * totalShares) / token.balanceOf(address(this));
|
|
68
|
+
}
|
|
69
|
+
```
|
|
70
|
+
|
|
71
|
+
```solidity
|
|
72
|
+
// Safe
|
|
73
|
+
uint256 private _totalAssets;
|
|
74
|
+
|
|
75
|
+
function deposit(uint256 assets) external nonReentrant returns (uint256 shares) {
|
|
76
|
+
uint256 balBefore = token.balanceOf(address(this));
|
|
77
|
+
token.safeTransferFrom(msg.sender, address(this), assets);
|
|
78
|
+
uint256 received = token.balanceOf(address(this)) - balBefore;
|
|
79
|
+
|
|
80
|
+
shares = totalShares == 0 ? received : (received * totalShares) / _totalAssets;
|
|
81
|
+
_totalAssets += received;
|
|
82
|
+
totalShares += shares;
|
|
83
|
+
}
|
|
84
|
+
```
|
|
85
|
+
|
|
86
|
+
Track internal accounting and measure actual tokens received.
|
|
87
|
+
|
|
88
|
+
### Oracle manipulation
|
|
89
|
+
|
|
90
|
+
Spot prices are flash-loan manipulable. Prefer TWAP.
|
|
91
|
+
|
|
92
|
+
```solidity
|
|
93
|
+
uint32[] memory secondsAgos = new uint32[](2);
|
|
94
|
+
secondsAgos[0] = 1800;
|
|
95
|
+
secondsAgos[1] = 0;
|
|
96
|
+
(int56[] memory tickCumulatives,) = IUniswapV3Pool(pool).observe(secondsAgos);
|
|
97
|
+
int24 twapTick = int24(
|
|
98
|
+
(tickCumulatives[1] - tickCumulatives[0]) / int56(uint56(30 minutes))
|
|
99
|
+
);
|
|
100
|
+
uint160 sqrtPriceX96 = TickMath.getSqrtRatioAtTick(twapTick);
|
|
101
|
+
```
|
|
102
|
+
|
|
103
|
+
### Slippage protection
|
|
104
|
+
|
|
105
|
+
Every swap path needs caller-provided slippage and a deadline.
|
|
106
|
+
|
|
107
|
+
```solidity
|
|
108
|
+
function swap(
|
|
109
|
+
uint256 amountIn,
|
|
110
|
+
uint256 amountOutMin,
|
|
111
|
+
uint256 deadline
|
|
112
|
+
) external returns (uint256 amountOut) {
|
|
113
|
+
require(block.timestamp <= deadline, "Expired");
|
|
114
|
+
amountOut = _calculateOut(amountIn);
|
|
115
|
+
require(amountOut >= amountOutMin, "Slippage exceeded");
|
|
116
|
+
_executeSwap(amountIn, amountOut);
|
|
117
|
+
}
|
|
118
|
+
```
|
|
119
|
+
|
|
120
|
+
### Safe reserve math
|
|
121
|
+
|
|
122
|
+
```solidity
|
|
123
|
+
import {FullMath} from "@uniswap/v3-core/contracts/libraries/FullMath.sol";
|
|
124
|
+
|
|
125
|
+
uint256 result = FullMath.mulDiv(a, b, c);
|
|
126
|
+
```
|
|
127
|
+
|
|
128
|
+
For large reserve math, avoid naive `a * b / c` when overflow risk exists.
|
|
129
|
+
|
|
130
|
+
### Admin controls
|
|
131
|
+
|
|
132
|
+
```solidity
|
|
133
|
+
import {Ownable2Step} from "@openzeppelin/contracts/access/Ownable2Step.sol";
|
|
134
|
+
|
|
135
|
+
contract MyAMM is Ownable2Step {
|
|
136
|
+
function setFee(uint256 fee) external onlyOwner { ... }
|
|
137
|
+
function pause() external onlyOwner { ... }
|
|
138
|
+
}
|
|
139
|
+
```
|
|
140
|
+
|
|
141
|
+
Prefer explicit acceptance for ownership transfer and gate every privileged path.
|
|
142
|
+
|
|
143
|
+
## Security Checklist
|
|
144
|
+
|
|
145
|
+
- Reentrancy-exposed entrypoints use `nonReentrant`
|
|
146
|
+
- CEI ordering is respected
|
|
147
|
+
- Share math does not depend on raw `balanceOf(address(this))`
|
|
148
|
+
- ERC-20 transfers use `SafeERC20`
|
|
149
|
+
- Deposits measure actual tokens received
|
|
150
|
+
- Oracle reads use TWAP or another manipulation-resistant source
|
|
151
|
+
- Swaps require `amountOutMin` and `deadline`
|
|
152
|
+
- Overflow-sensitive reserve math uses safe primitives like `mulDiv`
|
|
153
|
+
- Admin functions are access-controlled
|
|
154
|
+
- Emergency pause exists and is tested
|
|
155
|
+
- Static analysis and fuzzing are run before production
|
|
156
|
+
|
|
157
|
+
## Audit Tools
|
|
158
|
+
|
|
159
|
+
```bash
|
|
160
|
+
pip install slither-analyzer
|
|
161
|
+
slither . --exclude-dependencies
|
|
162
|
+
|
|
163
|
+
echidna-test . --contract YourAMM --config echidna.yaml
|
|
164
|
+
|
|
165
|
+
forge test --fuzz-runs 10000
|
|
166
|
+
```
|