@heyai-rules/pilo-masterkit 1.2.2 → 3.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.agent/agents/architect.md +211 -211
- package/.agent/agents/build-error-resolver.md +114 -114
- package/.agent/agents/chief-of-staff.md +151 -151
- package/.agent/agents/code-reviewer.md +237 -237
- package/.agent/agents/cpp-build-resolver.md +90 -90
- package/.agent/agents/cpp-reviewer.md +72 -72
- package/.agent/agents/csharp-reviewer.md +101 -0
- package/.agent/agents/dart-build-resolver.md +201 -0
- package/.agent/agents/database-reviewer.md +91 -91
- package/.agent/agents/doc-updater.md +107 -107
- package/.agent/agents/docs-lookup.md +68 -68
- package/.agent/agents/e2e-runner.md +107 -107
- package/.agent/agents/flutter-reviewer.md +243 -243
- package/.agent/agents/gan-evaluator.md +209 -0
- package/.agent/agents/gan-generator.md +131 -0
- package/.agent/agents/gan-planner.md +99 -0
- package/.agent/agents/go-build-resolver.md +94 -94
- package/.agent/agents/go-reviewer.md +76 -76
- package/.agent/agents/harness-optimizer.md +35 -35
- package/.agent/agents/healthcare-reviewer.md +83 -0
- package/.agent/agents/java-build-resolver.md +153 -153
- package/.agent/agents/java-reviewer.md +92 -92
- package/.agent/agents/kotlin-build-resolver.md +118 -118
- package/.agent/agents/kotlin-reviewer.md +159 -159
- package/.agent/agents/loop-operator.md +36 -36
- package/.agent/agents/opensource-forker.md +198 -0
- package/.agent/agents/opensource-packager.md +249 -0
- package/.agent/agents/opensource-sanitizer.md +188 -0
- package/.agent/agents/performance-optimizer.md +392 -133
- package/.agent/agents/personas/athena-agent/agent.json +10 -0
- package/.agent/agents/personas/athena-agent/athena-backend-logic-architecture-profile.md +189 -0
- package/.agent/agents/personas/athena-agent/context-files/agents.md +55 -0
- package/.agent/agents/personas/athena-agent/context-files/identity.md +23 -0
- package/.agent/agents/personas/athena-agent/context-files/soul.md +51 -0
- package/.agent/agents/personas/athena-agent/context-files/user-predefined.md +15 -0
- package/.agent/agents/personas/athena-agent/user-context-files/system/bootstrap.md +37 -0
- package/.agent/agents/personas/athena-agent/user-context-files/system/user.md +45 -0
- package/.agent/agents/personas/da-vinci-agent/agent.json +10 -0
- package/.agent/agents/personas/da-vinci-agent/context-files/agents.md +55 -0
- package/.agent/agents/personas/da-vinci-agent/context-files/identity.md +23 -0
- package/.agent/agents/personas/da-vinci-agent/context-files/soul.md +51 -0
- package/.agent/agents/personas/da-vinci-agent/context-files/user-predefined.md +15 -0
- package/.agent/agents/personas/da-vinci-agent/da-vinci-frontend-ui-ux-design-profile.md +189 -0
- package/.agent/agents/personas/da-vinci-agent/user-context-files/system/bootstrap.md +37 -0
- package/.agent/agents/personas/da-vinci-agent/user-context-files/system/user.md +45 -0
- package/.agent/agents/personas/duong-tang-agent/agent.json +10 -0
- package/.agent/agents/personas/duong-tang-agent/context-files/agents.md +55 -0
- package/.agent/agents/personas/duong-tang-agent/context-files/identity.md +23 -0
- package/.agent/agents/personas/duong-tang-agent/context-files/soul.md +51 -0
- package/.agent/agents/personas/duong-tang-agent/context-files/user-predefined.md +15 -0
- package/.agent/agents/personas/duong-tang-agent/tang-monk-quality-testing-documentation-profile.md +189 -0
- package/.agent/agents/personas/duong-tang-agent/user-context-files/system/bootstrap.md +37 -0
- package/.agent/agents/personas/duong-tang-agent/user-context-files/system/user.md +45 -0
- package/.agent/agents/personas/gia-cat-luong-agent/agent.json +10 -0
- package/.agent/agents/personas/gia-cat-luong-agent/context-files/agents.md +55 -0
- package/.agent/agents/personas/gia-cat-luong-agent/context-files/identity.md +23 -0
- package/.agent/agents/personas/gia-cat-luong-agent/context-files/soul.md +51 -0
- package/.agent/agents/personas/gia-cat-luong-agent/context-files/user-predefined.md +15 -0
- package/.agent/agents/personas/gia-cat-luong-agent/kongming-research-strategy-analysis-profile.md +189 -0
- package/.agent/agents/personas/gia-cat-luong-agent/user-context-files/system/bootstrap.md +37 -0
- package/.agent/agents/personas/gia-cat-luong-agent/user-context-files/system/user.md +45 -0
- package/.agent/agents/personas/mihata-agent/agent.json +10 -0
- package/.agent/agents/personas/mihata-agent/context-files/agents.md +55 -0
- package/.agent/agents/personas/mihata-agent/context-files/identity.md +23 -0
- package/.agent/agents/personas/mihata-agent/context-files/soul.md +51 -0
- package/.agent/agents/personas/mihata-agent/context-files/user-predefined.md +15 -0
- package/.agent/agents/personas/mihata-agent/mihata-multi-agent-orchestration-profile.md +189 -0
- package/.agent/agents/personas/mihata-agent/user-context-files/system/bootstrap.md +37 -0
- package/.agent/agents/personas/mihata-agent/user-context-files/system/user.md +45 -0
- package/.agent/agents/personas/tesla-agent/agent.json +10 -0
- package/.agent/agents/personas/tesla-agent/context-files/agents.md +55 -0
- package/.agent/agents/personas/tesla-agent/context-files/identity.md +23 -0
- package/.agent/agents/personas/tesla-agent/context-files/soul.md +51 -0
- package/.agent/agents/personas/tesla-agent/context-files/user-predefined.md +15 -0
- package/.agent/agents/personas/tesla-agent/tesla-fullstack-system-optimization-profile.md +189 -0
- package/.agent/agents/personas/tesla-agent/user-context-files/system/bootstrap.md +37 -0
- package/.agent/agents/personas/tesla-agent/user-context-files/system/user.md +45 -0
- package/.agent/agents/personas/tu-ma-y-agent/agent.json +10 -0
- package/.agent/agents/personas/tu-ma-y-agent/context-files/agents.md +55 -0
- package/.agent/agents/personas/tu-ma-y-agent/context-files/identity.md +23 -0
- package/.agent/agents/personas/tu-ma-y-agent/context-files/soul.md +51 -0
- package/.agent/agents/personas/tu-ma-y-agent/context-files/user-predefined.md +15 -0
- package/.agent/agents/personas/tu-ma-y-agent/simayi-feasibility-risk-control-profile.md +189 -0
- package/.agent/agents/personas/tu-ma-y-agent/user-context-files/system/bootstrap.md +37 -0
- package/.agent/agents/personas/tu-ma-y-agent/user-context-files/system/user.md +45 -0
- package/.agent/agents/personas/venti-agent/agent.json +10 -0
- package/.agent/agents/personas/venti-agent/context-files/agents.md +55 -0
- package/.agent/agents/personas/venti-agent/context-files/identity.md +23 -0
- package/.agent/agents/personas/venti-agent/context-files/soul.md +51 -0
- package/.agent/agents/personas/venti-agent/context-files/user-predefined.md +15 -0
- package/.agent/agents/personas/venti-agent/user-context-files/system/bootstrap.md +37 -0
- package/.agent/agents/personas/venti-agent/user-context-files/system/user.md +45 -0
- package/.agent/agents/personas/venti-agent/venti-learning-communication-mentoring-profile.md +189 -0
- package/.agent/agents/planner.md +212 -212
- package/.agent/agents/python-reviewer.md +98 -98
- package/.agent/agents/pytorch-build-resolver.md +120 -120
- package/.agent/agents/refactor-cleaner.md +85 -85
- package/.agent/agents/rust-build-resolver.md +148 -148
- package/.agent/agents/rust-reviewer.md +94 -94
- package/.agent/agents/security-reviewer.md +108 -108
- package/.agent/agents/tdd-guide.md +91 -91
- package/.agent/agents/typescript-reviewer.md +112 -112
- package/.agent/contexts/dev.md +20 -0
- package/.agent/contexts/research.md +26 -0
- package/.agent/contexts/review.md +22 -0
- package/.agent/hooks/hooks.json +395 -0
- package/.agent/hooks/readme.md +222 -0
- package/.agent/mcp-configs/mcp-servers.json +181 -0
- package/.agent/rules/common/agents.md +50 -0
- package/.agent/rules/common/code-review.md +124 -0
- package/.agent/rules/common/coding-style.md +48 -0
- package/.agent/rules/common/development-workflow.md +44 -0
- package/.agent/rules/common/git-workflow.md +24 -0
- package/.agent/rules/common/hooks.md +30 -0
- package/.agent/rules/common/patterns.md +31 -0
- package/.agent/rules/common/performance.md +55 -0
- package/.agent/rules/common/security.md +29 -0
- package/.agent/rules/common/testing.md +29 -0
- package/.agent/rules/cpp/coding-style.md +44 -0
- package/.agent/rules/cpp/hooks.md +39 -0
- package/.agent/rules/cpp/patterns.md +51 -0
- package/.agent/rules/cpp/security.md +51 -0
- package/.agent/rules/cpp/testing.md +44 -0
- package/.agent/rules/csharp/coding-style.md +72 -0
- package/.agent/rules/csharp/hooks.md +25 -0
- package/.agent/rules/csharp/patterns.md +50 -0
- package/.agent/rules/csharp/security.md +58 -0
- package/.agent/rules/csharp/testing.md +46 -0
- package/.agent/rules/dart/coding-style.md +159 -0
- package/.agent/rules/dart/hooks.md +66 -0
- package/.agent/rules/dart/patterns.md +261 -0
- package/.agent/rules/dart/security.md +135 -0
- package/.agent/rules/dart/testing.md +215 -0
- package/.agent/rules/golang/coding-style.md +32 -0
- package/.agent/rules/golang/hooks.md +17 -0
- package/.agent/rules/golang/patterns.md +45 -0
- package/.agent/rules/golang/security.md +34 -0
- package/.agent/rules/golang/testing.md +31 -0
- package/.agent/rules/java/coding-style.md +114 -0
- package/.agent/rules/java/hooks.md +18 -0
- package/.agent/rules/java/patterns.md +146 -0
- package/.agent/rules/java/security.md +100 -0
- package/.agent/rules/java/testing.md +131 -0
- package/.agent/rules/kotlin/coding-style.md +86 -0
- package/.agent/rules/kotlin/hooks.md +17 -0
- package/.agent/rules/kotlin/patterns.md +146 -0
- package/.agent/rules/kotlin/security.md +82 -0
- package/.agent/rules/kotlin/testing.md +128 -0
- package/.agent/rules/perl/coding-style.md +46 -0
- package/.agent/rules/perl/hooks.md +22 -0
- package/.agent/rules/perl/patterns.md +76 -0
- package/.agent/rules/perl/security.md +69 -0
- package/.agent/rules/perl/testing.md +54 -0
- package/.agent/rules/php/coding-style.md +40 -0
- package/.agent/rules/php/hooks.md +24 -0
- package/.agent/rules/php/patterns.md +33 -0
- package/.agent/rules/php/security.md +37 -0
- package/.agent/rules/php/testing.md +39 -0
- package/.agent/rules/python/coding-style.md +42 -0
- package/.agent/rules/python/hooks.md +19 -0
- package/.agent/rules/python/patterns.md +39 -0
- package/.agent/rules/python/security.md +30 -0
- package/.agent/rules/python/testing.md +38 -0
- package/.agent/rules/readme.md +111 -0
- package/.agent/rules/rust/coding-style.md +151 -0
- package/.agent/rules/rust/hooks.md +16 -0
- package/.agent/rules/rust/patterns.md +168 -0
- package/.agent/rules/rust/security.md +141 -0
- package/.agent/rules/rust/testing.md +154 -0
- package/.agent/rules/swift/coding-style.md +47 -0
- package/.agent/rules/swift/hooks.md +20 -0
- package/.agent/rules/swift/patterns.md +66 -0
- package/.agent/rules/swift/security.md +33 -0
- package/.agent/rules/swift/testing.md +45 -0
- package/.agent/rules/typescript/coding-style.md +199 -0
- package/.agent/rules/typescript/hooks.md +22 -0
- package/.agent/rules/typescript/patterns.md +52 -0
- package/.agent/rules/typescript/security.md +28 -0
- package/.agent/rules/typescript/testing.md +18 -0
- package/.agent/rules/web/coding-style.md +96 -0
- package/.agent/rules/web/design-quality.md +63 -0
- package/.agent/rules/web/hooks.md +120 -0
- package/.agent/rules/web/patterns.md +79 -0
- package/.agent/rules/web/performance.md +64 -0
- package/.agent/rules/web/security.md +57 -0
- package/.agent/rules/web/testing.md +55 -0
- package/.agent/rules/zh/agents.md +50 -0
- package/.agent/rules/zh/code-review.md +124 -0
- package/.agent/rules/zh/coding-style.md +48 -0
- package/.agent/rules/zh/development-workflow.md +44 -0
- package/.agent/rules/zh/git-workflow.md +24 -0
- package/.agent/rules/zh/hooks.md +30 -0
- package/.agent/rules/zh/patterns.md +31 -0
- package/.agent/rules/zh/performance.md +55 -0
- package/.agent/rules/zh/readme.md +108 -0
- package/.agent/rules/zh/security.md +29 -0
- package/.agent/rules/zh/testing.md +29 -0
- package/.agent/skills/agent-eval/SKILL.md +145 -0
- package/.agent/skills/agent-harness-construction/SKILL.md +73 -0
- package/.agent/skills/agent-payment-x402/SKILL.md +178 -0
- package/.agent/skills/agentic-engineering/SKILL.md +63 -0
- package/.agent/skills/ai-first-engineering/SKILL.md +51 -0
- package/.agent/skills/ai-regression-testing/SKILL.md +385 -0
- package/.agent/skills/android-clean-architecture/SKILL.md +339 -0
- package/.agent/skills/api-design/SKILL.md +523 -0
- package/.agent/skills/architecture-decision-records/SKILL.md +179 -0
- package/.agent/skills/article-writing/SKILL.md +79 -0
- package/.agent/skills/autonomous-agent-harness/SKILL.md +267 -0
- package/.agent/skills/autonomous-loops/SKILL.md +610 -0
- package/.agent/skills/backend-patterns/SKILL.md +598 -0
- package/.agent/skills/benchmark/SKILL.md +93 -0
- package/.agent/skills/blueprint/SKILL.md +105 -0
- package/.agent/skills/brand-voice/SKILL.md +97 -0
- package/.agent/skills/brand-voice/references/voice-profile-schema.md +55 -0
- package/.agent/skills/browser-qa/SKILL.md +87 -0
- package/.agent/skills/bun-runtime/SKILL.md +84 -0
- package/.agent/skills/canary-watch/SKILL.md +99 -0
- package/.agent/skills/carrier-relationship-management/SKILL.md +212 -0
- package/.agent/skills/ck/SKILL.md +147 -0
- package/.agent/skills/ck/commands/forget.mjs +44 -0
- package/.agent/skills/ck/commands/info.mjs +24 -0
- package/.agent/skills/ck/commands/init.mjs +143 -0
- package/.agent/skills/ck/commands/list.mjs +40 -0
- package/.agent/skills/ck/commands/migrate.mjs +202 -0
- package/.agent/skills/ck/commands/resume.mjs +36 -0
- package/.agent/skills/ck/commands/save.mjs +210 -0
- package/.agent/skills/ck/commands/shared.mjs +387 -0
- package/.agent/skills/ck/hooks/session-start.mjs +224 -0
- package/.agent/skills/claude-api/SKILL.md +337 -0
- package/.agent/skills/claude-devfleet/SKILL.md +103 -0
- package/.agent/skills/click-path-audit/SKILL.md +244 -0
- package/.agent/skills/clickhouse-io/SKILL.md +439 -0
- package/.agent/skills/codebase-onboarding/SKILL.md +233 -0
- package/.agent/skills/coding-standards/SKILL.md +530 -0
- package/.agent/skills/compose-multiplatform-patterns/SKILL.md +299 -0
- package/.agent/skills/configure-ecc/SKILL.md +367 -0
- package/.agent/skills/connections-optimizer/SKILL.md +189 -0
- package/.agent/skills/content-engine/SKILL.md +131 -0
- package/.agent/skills/content-hash-cache-pattern/SKILL.md +161 -0
- package/.agent/skills/context-budget/SKILL.md +135 -0
- package/.agent/skills/continuous-agent-loop/SKILL.md +45 -0
- package/.agent/skills/continuous-learning/SKILL.md +119 -0
- package/.agent/skills/continuous-learning/config.json +18 -0
- package/.agent/skills/continuous-learning/evaluate-session.sh +69 -0
- package/.agent/skills/continuous-learning-v2/SKILL.md +365 -0
- package/.agent/skills/continuous-learning-v2/agents/observer-loop.sh +271 -0
- package/.agent/skills/continuous-learning-v2/agents/observer.md +198 -0
- package/.agent/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
- package/.agent/skills/continuous-learning-v2/agents/start-observer.sh +244 -0
- package/.agent/skills/continuous-learning-v2/config.json +8 -0
- package/.agent/skills/continuous-learning-v2/hooks/observe.sh +428 -0
- package/.agent/skills/continuous-learning-v2/scripts/detect-project.sh +228 -0
- package/.agent/skills/continuous-learning-v2/scripts/instinct-cli.py +1426 -0
- package/.agent/skills/continuous-learning-v2/scripts/test-parse-instinct.py +984 -0
- package/.agent/skills/cost-aware-llm-pipeline/SKILL.md +183 -0
- package/.agent/skills/cpp-coding-standards/SKILL.md +723 -0
- package/.agent/skills/cpp-testing/SKILL.md +324 -0
- package/.agent/skills/crosspost/SKILL.md +111 -0
- package/.agent/skills/csharp-testing/SKILL.md +321 -0
- package/.agent/skills/customer-billing-ops/SKILL.md +140 -0
- package/.agent/skills/customs-trade-compliance/SKILL.md +263 -0
- package/.agent/skills/dart-flutter-patterns/SKILL.md +563 -0
- package/.agent/skills/data-scraper-agent/SKILL.md +764 -0
- package/.agent/skills/database-migrations/SKILL.md +429 -0
- package/.agent/skills/deep-research/SKILL.md +155 -0
- package/.agent/skills/deployment-patterns/SKILL.md +427 -0
- package/.agent/skills/design-system/SKILL.md +82 -0
- package/.agent/skills/django-patterns/SKILL.md +734 -0
- package/.agent/skills/django-security/SKILL.md +593 -0
- package/.agent/skills/django-tdd/SKILL.md +729 -0
- package/.agent/skills/django-verification/SKILL.md +469 -0
- package/.agent/skills/dmux-workflows/SKILL.md +191 -0
- package/.agent/skills/docker-patterns/SKILL.md +364 -0
- package/.agent/skills/documentation-lookup/SKILL.md +90 -0
- package/.agent/skills/dotnet-patterns/SKILL.md +321 -0
- package/.agent/skills/e2e-testing/SKILL.md +326 -0
- package/.agent/skills/energy-procurement/SKILL.md +228 -0
- package/.agent/skills/enterprise-agent-ops/SKILL.md +50 -0
- package/.agent/skills/eval-harness/SKILL.md +270 -0
- package/.agent/skills/exa-search/SKILL.md +103 -0
- package/.agent/skills/fal-ai-media/SKILL.md +284 -0
- package/.agent/skills/flutter-dart-code-review/SKILL.md +435 -0
- package/.agent/skills/foundation-models-on-device/SKILL.md +243 -0
- package/.agent/skills/frontend-patterns/SKILL.md +642 -0
- package/.agent/skills/frontend-slides/SKILL.md +184 -0
- package/.agent/skills/frontend-slides/style-presets.md +330 -0
- package/.agent/skills/gan-style-harness/SKILL.md +278 -0
- package/.agent/skills/git-workflow/SKILL.md +715 -0
- package/.agent/skills/golang-patterns/SKILL.md +674 -0
- package/.agent/skills/golang-testing/SKILL.md +720 -0
- package/.agent/skills/google-workspace-ops/SKILL.md +95 -0
- package/.agent/skills/healthcare-cdss-patterns/SKILL.md +245 -0
- package/.agent/skills/healthcare-emr-patterns/SKILL.md +159 -0
- package/.agent/skills/healthcare-eval-harness/SKILL.md +207 -0
- package/.agent/skills/healthcare-phi-compliance/SKILL.md +145 -0
- package/.agent/skills/hexagonal-architecture/SKILL.md +276 -0
- package/.agent/skills/inventory-demand-planning/SKILL.md +247 -0
- package/.agent/skills/investor-materials/SKILL.md +96 -0
- package/.agent/skills/investor-outreach/SKILL.md +91 -0
- package/.agent/skills/iterative-retrieval/SKILL.md +211 -0
- package/.agent/skills/java-coding-standards/SKILL.md +147 -0
- package/.agent/skills/jira-integration/SKILL.md +293 -0
- package/.agent/skills/jpa-patterns/SKILL.md +151 -0
- package/.agent/skills/kotlin-coroutines-flows/SKILL.md +284 -0
- package/.agent/skills/kotlin-exposed-patterns/SKILL.md +719 -0
- package/.agent/skills/kotlin-ktor-patterns/SKILL.md +689 -0
- package/.agent/skills/kotlin-patterns/SKILL.md +711 -0
- package/.agent/skills/kotlin-testing/SKILL.md +824 -0
- package/.agent/skills/laravel-patterns/SKILL.md +415 -0
- package/.agent/skills/laravel-plugin-discovery/SKILL.md +229 -0
- package/.agent/skills/laravel-security/SKILL.md +285 -0
- package/.agent/skills/laravel-tdd/SKILL.md +283 -0
- package/.agent/skills/laravel-verification/SKILL.md +179 -0
- package/.agent/skills/lead-intelligence/SKILL.md +321 -0
- package/.agent/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
- package/.agent/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
- package/.agent/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
- package/.agent/skills/lead-intelligence/agents/signal-scorer.md +60 -0
- package/.agent/skills/liquid-glass-design/SKILL.md +279 -0
- package/.agent/skills/logistics-exception-management/SKILL.md +222 -0
- package/.agent/skills/manim-video/SKILL.md +89 -0
- package/.agent/skills/manim-video/assets/network-graph-scene.py +52 -0
- package/.agent/skills/market-research/SKILL.md +75 -0
- package/.agent/skills/mcp-builder/SKILL.md +173 -113
- package/.agent/skills/mcp-builder/license.txt +202 -0
- package/.agent/skills/mcp-builder/reference/evaluation.md +602 -0
- package/.agent/skills/mcp-builder/reference/mcp-best-practices.md +249 -0
- package/.agent/skills/mcp-builder/reference/node-mcp-server.md +970 -0
- package/.agent/skills/mcp-builder/reference/python-mcp-server.md +719 -0
- package/.agent/skills/mcp-builder/scripts/connections.py +151 -0
- package/.agent/skills/mcp-builder/scripts/evaluation.py +373 -0
- package/.agent/skills/mcp-builder/scripts/example-evaluation.xml +22 -0
- package/.agent/skills/mcp-builder/scripts/requirements.txt +2 -0
- package/.agent/skills/mcp-server-patterns/SKILL.md +67 -0
- package/.agent/skills/nanoclaw-repl/SKILL.md +33 -0
- package/.agent/skills/nestjs-patterns/SKILL.md +230 -0
- package/.agent/skills/nextjs-turbopack/SKILL.md +44 -0
- package/.agent/skills/nutrient-document-processing/SKILL.md +167 -0
- package/.agent/skills/nuxt4-patterns/SKILL.md +100 -0
- package/.agent/skills/openclaw-persona-forge/SKILL.md +296 -0
- package/.agent/skills/openclaw-persona-forge/gacha.py +224 -0
- package/.agent/skills/openclaw-persona-forge/gacha.sh +5 -0
- package/.agent/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
- package/.agent/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
- package/.agent/skills/openclaw-persona-forge/references/error-handling.md +53 -0
- package/.agent/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
- package/.agent/skills/openclaw-persona-forge/references/naming-system.md +39 -0
- package/.agent/skills/openclaw-persona-forge/references/output-template.md +166 -0
- package/.agent/skills/opensource-pipeline/SKILL.md +255 -0
- package/.agent/skills/perl-patterns/SKILL.md +504 -0
- package/.agent/skills/perl-security/SKILL.md +503 -0
- package/.agent/skills/perl-testing/SKILL.md +475 -0
- package/.agent/skills/plankton-code-quality/SKILL.md +236 -0
- package/.agent/skills/postgres-patterns/SKILL.md +147 -0
- package/.agent/skills/product-lens/SKILL.md +85 -0
- package/.agent/skills/production-scheduling/SKILL.md +238 -0
- package/.agent/skills/project-flow-ops/SKILL.md +111 -0
- package/.agent/skills/project-guidelines-example/SKILL.md +349 -0
- package/.agent/skills/prompt-optimizer/SKILL.md +397 -0
- package/.agent/skills/python-patterns/SKILL.md +622 -313
- package/.agent/skills/python-testing/SKILL.md +816 -0
- package/.agent/skills/pytorch-patterns/SKILL.md +396 -0
- package/.agent/skills/quality-nonconformance/SKILL.md +260 -0
- package/.agent/skills/ralphinho-rfc-pipeline/SKILL.md +67 -0
- package/.agent/skills/regex-vs-llm-structured-text/SKILL.md +220 -0
- package/.agent/skills/remotion-video-creation/SKILL.md +43 -0
- package/.agent/skills/remotion-video-creation/rules/3d.md +86 -0
- package/.agent/skills/remotion-video-creation/rules/animations.md +29 -0
- package/.agent/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
- package/.agent/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
- package/.agent/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
- package/.agent/skills/remotion-video-creation/rules/assets.md +78 -0
- package/.agent/skills/remotion-video-creation/rules/audio.md +172 -0
- package/.agent/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
- package/.agent/skills/remotion-video-creation/rules/can-decode.md +75 -0
- package/.agent/skills/remotion-video-creation/rules/charts.md +58 -0
- package/.agent/skills/remotion-video-creation/rules/compositions.md +146 -0
- package/.agent/skills/remotion-video-creation/rules/display-captions.md +126 -0
- package/.agent/skills/remotion-video-creation/rules/extract-frames.md +229 -0
- package/.agent/skills/remotion-video-creation/rules/fonts.md +152 -0
- package/.agent/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
- package/.agent/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
- package/.agent/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
- package/.agent/skills/remotion-video-creation/rules/gifs.md +138 -0
- package/.agent/skills/remotion-video-creation/rules/images.md +130 -0
- package/.agent/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
- package/.agent/skills/remotion-video-creation/rules/lottie.md +67 -0
- package/.agent/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
- package/.agent/skills/remotion-video-creation/rules/measuring-text.md +143 -0
- package/.agent/skills/remotion-video-creation/rules/sequencing.md +106 -0
- package/.agent/skills/remotion-video-creation/rules/tailwind.md +11 -0
- package/.agent/skills/remotion-video-creation/rules/text-animations.md +20 -0
- package/.agent/skills/remotion-video-creation/rules/timing.md +179 -0
- package/.agent/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
- package/.agent/skills/remotion-video-creation/rules/transitions.md +122 -0
- package/.agent/skills/remotion-video-creation/rules/trimming.md +52 -0
- package/.agent/skills/remotion-video-creation/rules/videos.md +171 -0
- package/.agent/skills/repo-scan/SKILL.md +78 -0
- package/.agent/skills/returns-reverse-logistics/SKILL.md +240 -0
- package/.agent/skills/rules-distill/SKILL.md +264 -0
- package/.agent/skills/rules-distill/scripts/scan-rules.sh +58 -0
- package/.agent/skills/rules-distill/scripts/scan-skills.sh +129 -0
- package/.agent/skills/rust-patterns/SKILL.md +499 -0
- package/.agent/skills/rust-testing/SKILL.md +500 -0
- package/.agent/skills/safety-guard/SKILL.md +75 -0
- package/.agent/skills/santa-method/SKILL.md +306 -0
- package/.agent/skills/search-first/SKILL.md +161 -0
- package/.agent/skills/security-review/SKILL.md +495 -0
- package/.agent/skills/security-review/cloud-infrastructure-security.md +361 -0
- package/.agent/skills/security-scan/SKILL.md +165 -0
- package/.agent/skills/skill-comply/SKILL.md +58 -0
- package/.agent/skills/skill-comply/fixtures/compliant-trace.jsonl +5 -0
- package/.agent/skills/skill-comply/fixtures/noncompliant-trace.jsonl +3 -0
- package/.agent/skills/skill-comply/fixtures/tdd-spec.yaml +44 -0
- package/.agent/skills/skill-comply/prompts/classifier.md +24 -0
- package/.agent/skills/skill-comply/prompts/scenario-generator.md +62 -0
- package/.agent/skills/skill-comply/prompts/spec-generator.md +42 -0
- package/.agent/skills/skill-comply/pyproject.toml +15 -0
- package/.agent/skills/skill-comply/scripts/classifier.py +85 -0
- package/.agent/skills/skill-comply/scripts/grader.py +122 -0
- package/.agent/skills/skill-comply/scripts/init.py +0 -0
- package/.agent/skills/skill-comply/scripts/parser.py +107 -0
- package/.agent/skills/skill-comply/scripts/report.py +170 -0
- package/.agent/skills/skill-comply/scripts/run.py +127 -0
- package/.agent/skills/skill-comply/scripts/runner.py +161 -0
- package/.agent/skills/skill-comply/scripts/scenario-generator.py +70 -0
- package/.agent/skills/skill-comply/scripts/spec-generator.py +72 -0
- package/.agent/skills/skill-comply/scripts/utils.py +13 -0
- package/.agent/skills/skill-comply/tests/test-grader.py +137 -0
- package/.agent/skills/skill-comply/tests/test-parser.py +90 -0
- package/.agent/skills/skill-creator/SKILL.md +485 -0
- package/.agent/skills/skill-creator/agents/analyzer.md +274 -0
- package/.agent/skills/skill-creator/agents/comparator.md +202 -0
- package/.agent/skills/skill-creator/agents/grader.md +223 -0
- package/.agent/skills/skill-creator/assets/eval-review.html +146 -0
- package/.agent/skills/skill-creator/eval-viewer/generate-review.py +471 -0
- package/.agent/skills/skill-creator/eval-viewer/viewer.html +1325 -0
- package/.agent/skills/skill-creator/license.txt +202 -0
- package/.agent/skills/skill-creator/references/schemas.md +430 -0
- package/.agent/skills/skill-creator/scripts/aggregate-benchmark.py +401 -0
- package/.agent/skills/skill-creator/scripts/generate-report.py +326 -0
- package/.agent/skills/skill-creator/scripts/improve-description.py +247 -0
- package/.agent/skills/skill-creator/scripts/init.py +0 -0
- package/.agent/skills/skill-creator/scripts/package-skill.py +136 -0
- package/.agent/skills/skill-creator/scripts/quick-validate.py +103 -0
- package/.agent/skills/skill-creator/scripts/run-eval.py +310 -0
- package/.agent/skills/skill-creator/scripts/run-loop.py +328 -0
- package/.agent/skills/skill-creator/scripts/utils.py +47 -0
- package/.agent/skills/skill-stocktake/SKILL.md +193 -0
- package/.agent/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
- package/.agent/skills/skill-stocktake/scripts/save-results.sh +56 -0
- package/.agent/skills/skill-stocktake/scripts/scan.sh +170 -0
- package/.agent/skills/social-graph-ranker/SKILL.md +154 -0
- package/.agent/skills/springboot-patterns/SKILL.md +314 -0
- package/.agent/skills/springboot-security/SKILL.md +272 -0
- package/.agent/skills/springboot-tdd/SKILL.md +158 -0
- package/.agent/skills/springboot-verification/SKILL.md +231 -0
- package/.agent/skills/strategic-compact/SKILL.md +131 -0
- package/.agent/skills/strategic-compact/suggest-compact.sh +54 -0
- package/.agent/skills/swift-actor-persistence/SKILL.md +143 -0
- package/.agent/skills/swift-concurrency-6-2/SKILL.md +216 -0
- package/.agent/skills/swift-protocol-di-testing/SKILL.md +190 -0
- package/.agent/skills/swiftui-patterns/SKILL.md +259 -0
- package/.agent/skills/tdd-workflow/SKILL.md +412 -98
- package/.agent/skills/team-builder/SKILL.md +168 -0
- package/.agent/skills/token-budget-advisor/SKILL.md +133 -0
- package/.agent/skills/ui-demo/SKILL.md +465 -0
- package/.agent/skills/ui-ux-pro-max/data/charts.csv +26 -26
- package/.agent/skills/ui-ux-pro-max/data/colors.csv +97 -97
- package/.agent/skills/ui-ux-pro-max/data/landing.csv +28 -28
- package/.agent/skills/ui-ux-pro-max/data/products.csv +96 -96
- package/.agent/skills/ui-ux-pro-max/data/stacks/flutter.csv +53 -53
- package/.agent/skills/ui-ux-pro-max/data/stacks/html-tailwind.csv +56 -56
- package/.agent/skills/ui-ux-pro-max/data/stacks/nextjs.csv +53 -53
- package/.agent/skills/ui-ux-pro-max/data/stacks/react-native.csv +52 -52
- package/.agent/skills/ui-ux-pro-max/data/stacks/react.csv +54 -54
- package/.agent/skills/ui-ux-pro-max/data/stacks/svelte.csv +54 -54
- package/.agent/skills/ui-ux-pro-max/data/stacks/swiftui.csv +51 -51
- package/.agent/skills/ui-ux-pro-max/data/stacks/vue.csv +50 -50
- package/.agent/skills/ui-ux-pro-max/data/styles.csv +68 -68
- package/.agent/skills/ui-ux-pro-max/data/ux-guidelines.csv +99 -99
- package/.agent/skills/ui-ux-pro-max/scripts/search.py +114 -114
- package/.agent/skills/verification-loop/SKILL.md +126 -0
- package/.agent/skills/video-editing/SKILL.md +310 -0
- package/.agent/skills/videodb/SKILL.md +374 -0
- package/.agent/skills/videodb/reference/api-reference.md +550 -0
- package/.agent/skills/videodb/reference/capture-reference.md +407 -0
- package/.agent/skills/videodb/reference/capture.md +101 -0
- package/.agent/skills/videodb/reference/editor.md +443 -0
- package/.agent/skills/videodb/reference/generative.md +331 -0
- package/.agent/skills/videodb/reference/rtstream-reference.md +564 -0
- package/.agent/skills/videodb/reference/rtstream.md +65 -0
- package/.agent/skills/videodb/reference/search.md +230 -0
- package/.agent/skills/videodb/reference/streaming.md +406 -0
- package/.agent/skills/videodb/reference/use-cases.md +118 -0
- package/.agent/skills/videodb/scripts/ws-listener.py +282 -0
- package/.agent/skills/visa-doc-translate/SKILL.md +117 -0
- package/.agent/skills/visa-doc-translate/readme.md +86 -0
- package/.agent/skills/workspace-surface-audit/SKILL.md +125 -0
- package/.agent/skills/x-api/SKILL.md +230 -0
- package/.agent/tasks/two-track-merge-contract.md +29 -0
- package/.agent/workflows/aside.md +164 -164
- package/.agent/workflows/build-fix.md +62 -62
- package/.agent/workflows/checkpoint.md +74 -74
- package/.agent/workflows/claw.md +23 -51
- package/.agent/workflows/clean-memory.md +34 -0
- package/.agent/workflows/code-review.md +289 -40
- package/.agent/workflows/context-budget.md +23 -29
- package/.agent/workflows/cpp-build.md +173 -173
- package/.agent/workflows/cpp-review.md +132 -132
- package/.agent/workflows/cpp-test.md +251 -251
- package/.agent/workflows/devfleet.md +23 -92
- package/.agent/workflows/docs.md +23 -31
- package/.agent/workflows/e2e.md +268 -365
- package/.agent/workflows/eval.md +23 -120
- package/.agent/workflows/evolve.md +178 -178
- package/.agent/workflows/flutter-build.md +164 -0
- package/.agent/workflows/flutter-review.md +116 -0
- package/.agent/workflows/flutter-test.md +144 -0
- package/.agent/workflows/gan-build.md +99 -0
- package/.agent/workflows/gan-design.md +35 -0
- package/.agent/workflows/go-build.md +183 -183
- package/.agent/workflows/go-review.md +148 -148
- package/.agent/workflows/go-test.md +268 -268
- package/.agent/workflows/gradle-build.md +70 -70
- package/.agent/workflows/harness-audit.md +73 -71
- package/.agent/workflows/instinct-export.md +66 -66
- package/.agent/workflows/instinct-import.md +114 -114
- package/.agent/workflows/instinct-status.md +59 -59
- package/.agent/workflows/jira.md +106 -0
- package/.agent/workflows/kotlin-build.md +174 -174
- package/.agent/workflows/kotlin-review.md +140 -140
- package/.agent/workflows/kotlin-test.md +312 -312
- package/.agent/workflows/learn-eval.md +116 -116
- package/.agent/workflows/learn.md +70 -70
- package/.agent/workflows/loop-start.md +32 -32
- package/.agent/workflows/loop-status.md +24 -24
- package/.agent/workflows/model-route.md +26 -26
- package/.agent/workflows/multi-backend.md +158 -158
- package/.agent/workflows/multi-execute.md +315 -315
- package/.agent/workflows/multi-frontend.md +158 -158
- package/.agent/workflows/multi-plan.md +268 -268
- package/.agent/workflows/multi-workflow.md +191 -191
- package/.agent/workflows/orchestrate.md +135 -231
- package/.agent/workflows/plan.md +117 -115
- package/.agent/workflows/pm2.md +272 -272
- package/.agent/workflows/projects.md +39 -39
- package/.agent/workflows/promote.md +41 -41
- package/.agent/workflows/prompt-optimize.md +23 -38
- package/.agent/workflows/prp-commit.md +112 -0
- package/.agent/workflows/prp-implement.md +385 -0
- package/.agent/workflows/prp-plan.md +502 -0
- package/.agent/workflows/prp-pr.md +184 -0
- package/.agent/workflows/prp-prd.md +447 -0
- package/.agent/workflows/prune.md +31 -31
- package/.agent/workflows/python-review.md +297 -297
- package/.agent/workflows/quality-gate.md +29 -29
- package/.agent/workflows/refactor-clean.md +80 -80
- package/.agent/workflows/resume-session.md +156 -156
- package/.agent/workflows/rules-distill.md +20 -11
- package/.agent/workflows/rust-build.md +187 -187
- package/.agent/workflows/rust-review.md +142 -142
- package/.agent/workflows/rust-test.md +308 -308
- package/.agent/workflows/santa-loop.md +175 -0
- package/.agent/workflows/save-session.md +275 -275
- package/.agent/workflows/sessions.md +333 -333
- package/.agent/workflows/setup-pm.md +80 -80
- package/.agent/workflows/skill-create.md +174 -174
- package/.agent/workflows/skill-health.md +54 -54
- package/.agent/workflows/tdd.md +231 -328
- package/.agent/workflows/test-coverage.md +69 -69
- package/.agent/workflows/update-codemaps.md +72 -72
- package/.agent/workflows/update-docs.md +84 -84
- package/.agent/workflows/verify.md +23 -59
- package/LICENSE +176 -176
- package/README.md +28 -20
- package/RELEASE.md +32 -36
- package/package.json +87 -79
- package/scripts/release-check.js +55 -55
- package/src/bin/cli.js +399 -53
- package/src/lib/installer.js +360 -114
- package/src/lib/manifests/stacks.js +122 -0
- package/src/lib/slash-commands.js +28 -0
- package/src/templates/claude/CLAUDE.en.md +42 -0
- package/src/templates/claude/CLAUDE.md +42 -0
- package/src/templates/claude/CLAUDE.vi.md +42 -0
- package/src/templates/codex/AGENTS.en.md +40 -0
- package/src/templates/codex/AGENTS.md +40 -0
- package/src/templates/codex/AGENTS.vi.md +40 -0
- package/src/templates/cursor/pilo-masterkit.mdc +20 -0
- package/src/templates/gemini/GEMINI.en.md +56 -0
- package/src/templates/gemini/GEMINI.md +56 -0
- package/src/templates/gemini/GEMINI.vi.md +56 -0
- package/src/templates/github/copilot-instructions.md +16 -0
|
@@ -0,0 +1,523 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: api-design
|
|
3
|
+
description: REST API design patterns including resource naming, status codes, pagination, filtering, error responses, versioning, and rate limiting for production APIs.
|
|
4
|
+
origin: ECC
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# API Design Patterns
|
|
8
|
+
|
|
9
|
+
Conventions and best practices for designing consistent, developer-friendly REST APIs.
|
|
10
|
+
|
|
11
|
+
## When to Activate
|
|
12
|
+
|
|
13
|
+
- Designing new API endpoints
|
|
14
|
+
- Reviewing existing API contracts
|
|
15
|
+
- Adding pagination, filtering, or sorting
|
|
16
|
+
- Implementing error handling for APIs
|
|
17
|
+
- Planning API versioning strategy
|
|
18
|
+
- Building public or partner-facing APIs
|
|
19
|
+
|
|
20
|
+
## Resource Design
|
|
21
|
+
|
|
22
|
+
### URL Structure
|
|
23
|
+
|
|
24
|
+
```
|
|
25
|
+
# Resources are nouns, plural, lowercase, kebab-case
|
|
26
|
+
GET /api/v1/users
|
|
27
|
+
GET /api/v1/users/:id
|
|
28
|
+
POST /api/v1/users
|
|
29
|
+
PUT /api/v1/users/:id
|
|
30
|
+
PATCH /api/v1/users/:id
|
|
31
|
+
DELETE /api/v1/users/:id
|
|
32
|
+
|
|
33
|
+
# Sub-resources for relationships
|
|
34
|
+
GET /api/v1/users/:id/orders
|
|
35
|
+
POST /api/v1/users/:id/orders
|
|
36
|
+
|
|
37
|
+
# Actions that don't map to CRUD (use verbs sparingly)
|
|
38
|
+
POST /api/v1/orders/:id/cancel
|
|
39
|
+
POST /api/v1/auth/login
|
|
40
|
+
POST /api/v1/auth/refresh
|
|
41
|
+
```
|
|
42
|
+
|
|
43
|
+
### Naming Rules
|
|
44
|
+
|
|
45
|
+
```
|
|
46
|
+
# GOOD
|
|
47
|
+
/api/v1/team-members # kebab-case for multi-word resources
|
|
48
|
+
/api/v1/orders?status=active # query params for filtering
|
|
49
|
+
/api/v1/users/123/orders # nested resources for ownership
|
|
50
|
+
|
|
51
|
+
# BAD
|
|
52
|
+
/api/v1/getUsers # verb in URL
|
|
53
|
+
/api/v1/user # singular (use plural)
|
|
54
|
+
/api/v1/team_members # snake_case in URLs
|
|
55
|
+
/api/v1/users/123/getOrders # verb in nested resource
|
|
56
|
+
```
|
|
57
|
+
|
|
58
|
+
## HTTP Methods and Status Codes
|
|
59
|
+
|
|
60
|
+
### Method Semantics
|
|
61
|
+
|
|
62
|
+
| Method | Idempotent | Safe | Use For |
|
|
63
|
+
|--------|-----------|------|---------|
|
|
64
|
+
| GET | Yes | Yes | Retrieve resources |
|
|
65
|
+
| POST | No | No | Create resources, trigger actions |
|
|
66
|
+
| PUT | Yes | No | Full replacement of a resource |
|
|
67
|
+
| PATCH | No* | No | Partial update of a resource |
|
|
68
|
+
| DELETE | Yes | No | Remove a resource |
|
|
69
|
+
|
|
70
|
+
*PATCH can be made idempotent with proper implementation
|
|
71
|
+
|
|
72
|
+
### Status Code Reference
|
|
73
|
+
|
|
74
|
+
```
|
|
75
|
+
# Success
|
|
76
|
+
200 OK — GET, PUT, PATCH (with response body)
|
|
77
|
+
201 Created — POST (include Location header)
|
|
78
|
+
204 No Content — DELETE, PUT (no response body)
|
|
79
|
+
|
|
80
|
+
# Client Errors
|
|
81
|
+
400 Bad Request — Validation failure, malformed JSON
|
|
82
|
+
401 Unauthorized — Missing or invalid authentication
|
|
83
|
+
403 Forbidden — Authenticated but not authorized
|
|
84
|
+
404 Not Found — Resource doesn't exist
|
|
85
|
+
409 Conflict — Duplicate entry, state conflict
|
|
86
|
+
422 Unprocessable Entity — Semantically invalid (valid JSON, bad data)
|
|
87
|
+
429 Too Many Requests — Rate limit exceeded
|
|
88
|
+
|
|
89
|
+
# Server Errors
|
|
90
|
+
500 Internal Server Error — Unexpected failure (never expose details)
|
|
91
|
+
502 Bad Gateway — Upstream service failed
|
|
92
|
+
503 Service Unavailable — Temporary overload, include Retry-After
|
|
93
|
+
```
|
|
94
|
+
|
|
95
|
+
### Common Mistakes
|
|
96
|
+
|
|
97
|
+
```
|
|
98
|
+
# BAD: 200 for everything
|
|
99
|
+
{ "status": 200, "success": false, "error": "Not found" }
|
|
100
|
+
|
|
101
|
+
# GOOD: Use HTTP status codes semantically
|
|
102
|
+
HTTP/1.1 404 Not Found
|
|
103
|
+
{ "error": { "code": "not_found", "message": "User not found" } }
|
|
104
|
+
|
|
105
|
+
# BAD: 500 for validation errors
|
|
106
|
+
# GOOD: 400 or 422 with field-level details
|
|
107
|
+
|
|
108
|
+
# BAD: 200 for created resources
|
|
109
|
+
# GOOD: 201 with Location header
|
|
110
|
+
HTTP/1.1 201 Created
|
|
111
|
+
Location: /api/v1/users/abc-123
|
|
112
|
+
```
|
|
113
|
+
|
|
114
|
+
## Response Format
|
|
115
|
+
|
|
116
|
+
### Success Response
|
|
117
|
+
|
|
118
|
+
```json
|
|
119
|
+
{
|
|
120
|
+
"data": {
|
|
121
|
+
"id": "abc-123",
|
|
122
|
+
"email": "alice@example.com",
|
|
123
|
+
"name": "Alice",
|
|
124
|
+
"created_at": "2025-01-15T10:30:00Z"
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
```
|
|
128
|
+
|
|
129
|
+
### Collection Response (with Pagination)
|
|
130
|
+
|
|
131
|
+
```json
|
|
132
|
+
{
|
|
133
|
+
"data": [
|
|
134
|
+
{ "id": "abc-123", "name": "Alice" },
|
|
135
|
+
{ "id": "def-456", "name": "Bob" }
|
|
136
|
+
],
|
|
137
|
+
"meta": {
|
|
138
|
+
"total": 142,
|
|
139
|
+
"page": 1,
|
|
140
|
+
"per_page": 20,
|
|
141
|
+
"total_pages": 8
|
|
142
|
+
},
|
|
143
|
+
"links": {
|
|
144
|
+
"self": "/api/v1/users?page=1&per_page=20",
|
|
145
|
+
"next": "/api/v1/users?page=2&per_page=20",
|
|
146
|
+
"last": "/api/v1/users?page=8&per_page=20"
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
```
|
|
150
|
+
|
|
151
|
+
### Error Response
|
|
152
|
+
|
|
153
|
+
```json
|
|
154
|
+
{
|
|
155
|
+
"error": {
|
|
156
|
+
"code": "validation_error",
|
|
157
|
+
"message": "Request validation failed",
|
|
158
|
+
"details": [
|
|
159
|
+
{
|
|
160
|
+
"field": "email",
|
|
161
|
+
"message": "Must be a valid email address",
|
|
162
|
+
"code": "invalid_format"
|
|
163
|
+
},
|
|
164
|
+
{
|
|
165
|
+
"field": "age",
|
|
166
|
+
"message": "Must be between 0 and 150",
|
|
167
|
+
"code": "out_of_range"
|
|
168
|
+
}
|
|
169
|
+
]
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
```
|
|
173
|
+
|
|
174
|
+
### Response Envelope Variants
|
|
175
|
+
|
|
176
|
+
```typescript
|
|
177
|
+
// Option A: Envelope with data wrapper (recommended for public APIs)
|
|
178
|
+
interface ApiResponse<T> {
|
|
179
|
+
data: T;
|
|
180
|
+
meta?: PaginationMeta;
|
|
181
|
+
links?: PaginationLinks;
|
|
182
|
+
}
|
|
183
|
+
|
|
184
|
+
interface ApiError {
|
|
185
|
+
error: {
|
|
186
|
+
code: string;
|
|
187
|
+
message: string;
|
|
188
|
+
details?: FieldError[];
|
|
189
|
+
};
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
// Option B: Flat response (simpler, common for internal APIs)
|
|
193
|
+
// Success: just return the resource directly
|
|
194
|
+
// Error: return error object
|
|
195
|
+
// Distinguish by HTTP status code
|
|
196
|
+
```
|
|
197
|
+
|
|
198
|
+
## Pagination
|
|
199
|
+
|
|
200
|
+
### Offset-Based (Simple)
|
|
201
|
+
|
|
202
|
+
```
|
|
203
|
+
GET /api/v1/users?page=2&per_page=20
|
|
204
|
+
|
|
205
|
+
# Implementation
|
|
206
|
+
SELECT * FROM users
|
|
207
|
+
ORDER BY created_at DESC
|
|
208
|
+
LIMIT 20 OFFSET 20;
|
|
209
|
+
```
|
|
210
|
+
|
|
211
|
+
**Pros:** Easy to implement, supports "jump to page N"
|
|
212
|
+
**Cons:** Slow on large offsets (OFFSET 100000), inconsistent with concurrent inserts
|
|
213
|
+
|
|
214
|
+
### Cursor-Based (Scalable)
|
|
215
|
+
|
|
216
|
+
```
|
|
217
|
+
GET /api/v1/users?cursor=eyJpZCI6MTIzfQ&limit=20
|
|
218
|
+
|
|
219
|
+
# Implementation
|
|
220
|
+
SELECT * FROM users
|
|
221
|
+
WHERE id > :cursor_id
|
|
222
|
+
ORDER BY id ASC
|
|
223
|
+
LIMIT 21; -- fetch one extra to determine has_next
|
|
224
|
+
```
|
|
225
|
+
|
|
226
|
+
```json
|
|
227
|
+
{
|
|
228
|
+
"data": [...],
|
|
229
|
+
"meta": {
|
|
230
|
+
"has_next": true,
|
|
231
|
+
"next_cursor": "eyJpZCI6MTQzfQ"
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
```
|
|
235
|
+
|
|
236
|
+
**Pros:** Consistent performance regardless of position, stable with concurrent inserts
|
|
237
|
+
**Cons:** Cannot jump to arbitrary page, cursor is opaque
|
|
238
|
+
|
|
239
|
+
### When to Use Which
|
|
240
|
+
|
|
241
|
+
| Use Case | Pagination Type |
|
|
242
|
+
|----------|----------------|
|
|
243
|
+
| Admin dashboards, small datasets (<10K) | Offset |
|
|
244
|
+
| Infinite scroll, feeds, large datasets | Cursor |
|
|
245
|
+
| Public APIs | Cursor (default) with offset (optional) |
|
|
246
|
+
| Search results | Offset (users expect page numbers) |
|
|
247
|
+
|
|
248
|
+
## Filtering, Sorting, and Search
|
|
249
|
+
|
|
250
|
+
### Filtering
|
|
251
|
+
|
|
252
|
+
```
|
|
253
|
+
# Simple equality
|
|
254
|
+
GET /api/v1/orders?status=active&customer_id=abc-123
|
|
255
|
+
|
|
256
|
+
# Comparison operators (use bracket notation)
|
|
257
|
+
GET /api/v1/products?price[gte]=10&price[lte]=100
|
|
258
|
+
GET /api/v1/orders?created_at[after]=2025-01-01
|
|
259
|
+
|
|
260
|
+
# Multiple values (comma-separated)
|
|
261
|
+
GET /api/v1/products?category=electronics,clothing
|
|
262
|
+
|
|
263
|
+
# Nested fields (dot notation)
|
|
264
|
+
GET /api/v1/orders?customer.country=US
|
|
265
|
+
```
|
|
266
|
+
|
|
267
|
+
### Sorting
|
|
268
|
+
|
|
269
|
+
```
|
|
270
|
+
# Single field (prefix - for descending)
|
|
271
|
+
GET /api/v1/products?sort=-created_at
|
|
272
|
+
|
|
273
|
+
# Multiple fields (comma-separated)
|
|
274
|
+
GET /api/v1/products?sort=-featured,price,-created_at
|
|
275
|
+
```
|
|
276
|
+
|
|
277
|
+
### Full-Text Search
|
|
278
|
+
|
|
279
|
+
```
|
|
280
|
+
# Search query parameter
|
|
281
|
+
GET /api/v1/products?q=wireless+headphones
|
|
282
|
+
|
|
283
|
+
# Field-specific search
|
|
284
|
+
GET /api/v1/users?email=alice
|
|
285
|
+
```
|
|
286
|
+
|
|
287
|
+
### Sparse Fieldsets
|
|
288
|
+
|
|
289
|
+
```
|
|
290
|
+
# Return only specified fields (reduces payload)
|
|
291
|
+
GET /api/v1/users?fields=id,name,email
|
|
292
|
+
GET /api/v1/orders?fields=id,total,status&include=customer.name
|
|
293
|
+
```
|
|
294
|
+
|
|
295
|
+
## Authentication and Authorization
|
|
296
|
+
|
|
297
|
+
### Token-Based Auth
|
|
298
|
+
|
|
299
|
+
```
|
|
300
|
+
# Bearer token in Authorization header
|
|
301
|
+
GET /api/v1/users
|
|
302
|
+
Authorization: Bearer eyJhbGciOiJIUzI1NiIs...
|
|
303
|
+
|
|
304
|
+
# API key (for server-to-server)
|
|
305
|
+
GET /api/v1/data
|
|
306
|
+
X-API-Key: sk_live_abc123
|
|
307
|
+
```
|
|
308
|
+
|
|
309
|
+
### Authorization Patterns
|
|
310
|
+
|
|
311
|
+
```typescript
|
|
312
|
+
// Resource-level: check ownership
|
|
313
|
+
app.get("/api/v1/orders/:id", async (req, res) => {
|
|
314
|
+
const order = await Order.findById(req.params.id);
|
|
315
|
+
if (!order) return res.status(404).json({ error: { code: "not_found" } });
|
|
316
|
+
if (order.userId !== req.user.id) return res.status(403).json({ error: { code: "forbidden" } });
|
|
317
|
+
return res.json({ data: order });
|
|
318
|
+
});
|
|
319
|
+
|
|
320
|
+
// Role-based: check permissions
|
|
321
|
+
app.delete("/api/v1/users/:id", requireRole("admin"), async (req, res) => {
|
|
322
|
+
await User.delete(req.params.id);
|
|
323
|
+
return res.status(204).send();
|
|
324
|
+
});
|
|
325
|
+
```
|
|
326
|
+
|
|
327
|
+
## Rate Limiting
|
|
328
|
+
|
|
329
|
+
### Headers
|
|
330
|
+
|
|
331
|
+
```
|
|
332
|
+
HTTP/1.1 200 OK
|
|
333
|
+
X-RateLimit-Limit: 100
|
|
334
|
+
X-RateLimit-Remaining: 95
|
|
335
|
+
X-RateLimit-Reset: 1640000000
|
|
336
|
+
|
|
337
|
+
# When exceeded
|
|
338
|
+
HTTP/1.1 429 Too Many Requests
|
|
339
|
+
Retry-After: 60
|
|
340
|
+
{
|
|
341
|
+
"error": {
|
|
342
|
+
"code": "rate_limit_exceeded",
|
|
343
|
+
"message": "Rate limit exceeded. Try again in 60 seconds."
|
|
344
|
+
}
|
|
345
|
+
}
|
|
346
|
+
```
|
|
347
|
+
|
|
348
|
+
### Rate Limit Tiers
|
|
349
|
+
|
|
350
|
+
| Tier | Limit | Window | Use Case |
|
|
351
|
+
|------|-------|--------|----------|
|
|
352
|
+
| Anonymous | 30/min | Per IP | Public endpoints |
|
|
353
|
+
| Authenticated | 100/min | Per user | Standard API access |
|
|
354
|
+
| Premium | 1000/min | Per API key | Paid API plans |
|
|
355
|
+
| Internal | 10000/min | Per service | Service-to-service |
|
|
356
|
+
|
|
357
|
+
## Versioning
|
|
358
|
+
|
|
359
|
+
### URL Path Versioning (Recommended)
|
|
360
|
+
|
|
361
|
+
```
|
|
362
|
+
/api/v1/users
|
|
363
|
+
/api/v2/users
|
|
364
|
+
```
|
|
365
|
+
|
|
366
|
+
**Pros:** Explicit, easy to route, cacheable
|
|
367
|
+
**Cons:** URL changes between versions
|
|
368
|
+
|
|
369
|
+
### Header Versioning
|
|
370
|
+
|
|
371
|
+
```
|
|
372
|
+
GET /api/users
|
|
373
|
+
Accept: application/vnd.myapp.v2+json
|
|
374
|
+
```
|
|
375
|
+
|
|
376
|
+
**Pros:** Clean URLs
|
|
377
|
+
**Cons:** Harder to test, easy to forget
|
|
378
|
+
|
|
379
|
+
### Versioning Strategy
|
|
380
|
+
|
|
381
|
+
```
|
|
382
|
+
1. Start with /api/v1/ — don't version until you need to
|
|
383
|
+
2. Maintain at most 2 active versions (current + previous)
|
|
384
|
+
3. Deprecation timeline:
|
|
385
|
+
- Announce deprecation (6 months notice for public APIs)
|
|
386
|
+
- Add Sunset header: Sunset: Sat, 01 Jan 2026 00:00:00 GMT
|
|
387
|
+
- Return 410 Gone after sunset date
|
|
388
|
+
4. Non-breaking changes don't need a new version:
|
|
389
|
+
- Adding new fields to responses
|
|
390
|
+
- Adding new optional query parameters
|
|
391
|
+
- Adding new endpoints
|
|
392
|
+
5. Breaking changes require a new version:
|
|
393
|
+
- Removing or renaming fields
|
|
394
|
+
- Changing field types
|
|
395
|
+
- Changing URL structure
|
|
396
|
+
- Changing authentication method
|
|
397
|
+
```
|
|
398
|
+
|
|
399
|
+
## Implementation Patterns
|
|
400
|
+
|
|
401
|
+
### TypeScript (Next.js API Route)
|
|
402
|
+
|
|
403
|
+
```typescript
|
|
404
|
+
import { z } from "zod";
|
|
405
|
+
import { NextRequest, NextResponse } from "next/server";
|
|
406
|
+
|
|
407
|
+
const createUserSchema = z.object({
|
|
408
|
+
email: z.string().email(),
|
|
409
|
+
name: z.string().min(1).max(100),
|
|
410
|
+
});
|
|
411
|
+
|
|
412
|
+
export async function POST(req: NextRequest) {
|
|
413
|
+
const body = await req.json();
|
|
414
|
+
const parsed = createUserSchema.safeParse(body);
|
|
415
|
+
|
|
416
|
+
if (!parsed.success) {
|
|
417
|
+
return NextResponse.json({
|
|
418
|
+
error: {
|
|
419
|
+
code: "validation_error",
|
|
420
|
+
message: "Request validation failed",
|
|
421
|
+
details: parsed.error.issues.map(i => ({
|
|
422
|
+
field: i.path.join("."),
|
|
423
|
+
message: i.message,
|
|
424
|
+
code: i.code,
|
|
425
|
+
})),
|
|
426
|
+
},
|
|
427
|
+
}, { status: 422 });
|
|
428
|
+
}
|
|
429
|
+
|
|
430
|
+
const user = await createUser(parsed.data);
|
|
431
|
+
|
|
432
|
+
return NextResponse.json(
|
|
433
|
+
{ data: user },
|
|
434
|
+
{
|
|
435
|
+
status: 201,
|
|
436
|
+
headers: { Location: `/api/v1/users/${user.id}` },
|
|
437
|
+
},
|
|
438
|
+
);
|
|
439
|
+
}
|
|
440
|
+
```
|
|
441
|
+
|
|
442
|
+
### Python (Django REST Framework)
|
|
443
|
+
|
|
444
|
+
```python
|
|
445
|
+
from rest_framework import serializers, viewsets, status
|
|
446
|
+
from rest_framework.response import Response
|
|
447
|
+
|
|
448
|
+
class CreateUserSerializer(serializers.Serializer):
|
|
449
|
+
email = serializers.EmailField()
|
|
450
|
+
name = serializers.CharField(max_length=100)
|
|
451
|
+
|
|
452
|
+
class UserSerializer(serializers.ModelSerializer):
|
|
453
|
+
class Meta:
|
|
454
|
+
model = User
|
|
455
|
+
fields = ["id", "email", "name", "created_at"]
|
|
456
|
+
|
|
457
|
+
class UserViewSet(viewsets.ModelViewSet):
|
|
458
|
+
serializer_class = UserSerializer
|
|
459
|
+
permission_classes = [IsAuthenticated]
|
|
460
|
+
|
|
461
|
+
def get_serializer_class(self):
|
|
462
|
+
if self.action == "create":
|
|
463
|
+
return CreateUserSerializer
|
|
464
|
+
return UserSerializer
|
|
465
|
+
|
|
466
|
+
def create(self, request):
|
|
467
|
+
serializer = CreateUserSerializer(data=request.data)
|
|
468
|
+
serializer.is_valid(raise_exception=True)
|
|
469
|
+
user = UserService.create(**serializer.validated_data)
|
|
470
|
+
return Response(
|
|
471
|
+
{"data": UserSerializer(user).data},
|
|
472
|
+
status=status.HTTP_201_CREATED,
|
|
473
|
+
headers={"Location": f"/api/v1/users/{user.id}"},
|
|
474
|
+
)
|
|
475
|
+
```
|
|
476
|
+
|
|
477
|
+
### Go (net/http)
|
|
478
|
+
|
|
479
|
+
```go
|
|
480
|
+
func (h *UserHandler) CreateUser(w http.ResponseWriter, r *http.Request) {
|
|
481
|
+
var req CreateUserRequest
|
|
482
|
+
if err := json.NewDecoder(r.Body).Decode(&req); err != nil {
|
|
483
|
+
writeError(w, http.StatusBadRequest, "invalid_json", "Invalid request body")
|
|
484
|
+
return
|
|
485
|
+
}
|
|
486
|
+
|
|
487
|
+
if err := req.Validate(); err != nil {
|
|
488
|
+
writeError(w, http.StatusUnprocessableEntity, "validation_error", err.Error())
|
|
489
|
+
return
|
|
490
|
+
}
|
|
491
|
+
|
|
492
|
+
user, err := h.service.Create(r.Context(), req)
|
|
493
|
+
if err != nil {
|
|
494
|
+
switch {
|
|
495
|
+
case errors.Is(err, domain.ErrEmailTaken):
|
|
496
|
+
writeError(w, http.StatusConflict, "email_taken", "Email already registered")
|
|
497
|
+
default:
|
|
498
|
+
writeError(w, http.StatusInternalServerError, "internal_error", "Internal error")
|
|
499
|
+
}
|
|
500
|
+
return
|
|
501
|
+
}
|
|
502
|
+
|
|
503
|
+
w.Header().Set("Location", fmt.Sprintf("/api/v1/users/%s", user.ID))
|
|
504
|
+
writeJSON(w, http.StatusCreated, map[string]any{"data": user})
|
|
505
|
+
}
|
|
506
|
+
```
|
|
507
|
+
|
|
508
|
+
## API Design Checklist
|
|
509
|
+
|
|
510
|
+
Before shipping a new endpoint:
|
|
511
|
+
|
|
512
|
+
- [ ] Resource URL follows naming conventions (plural, kebab-case, no verbs)
|
|
513
|
+
- [ ] Correct HTTP method used (GET for reads, POST for creates, etc.)
|
|
514
|
+
- [ ] Appropriate status codes returned (not 200 for everything)
|
|
515
|
+
- [ ] Input validated with schema (Zod, Pydantic, Bean Validation)
|
|
516
|
+
- [ ] Error responses follow standard format with codes and messages
|
|
517
|
+
- [ ] Pagination implemented for list endpoints (cursor or offset)
|
|
518
|
+
- [ ] Authentication required (or explicitly marked as public)
|
|
519
|
+
- [ ] Authorization checked (user can only access their own resources)
|
|
520
|
+
- [ ] Rate limiting configured
|
|
521
|
+
- [ ] Response does not leak internal details (stack traces, SQL errors)
|
|
522
|
+
- [ ] Consistent naming with existing endpoints (camelCase vs snake_case)
|
|
523
|
+
- [ ] Documented (OpenAPI/Swagger spec updated)
|
|
@@ -0,0 +1,179 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: architecture-decision-records
|
|
3
|
+
description: Capture architectural decisions made during Claude Code sessions as structured ADRs. Auto-detects decision moments, records context, alternatives considered, and rationale. Maintains an ADR log so future developers understand why the codebase is shaped the way it is.
|
|
4
|
+
origin: ECC
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Architecture Decision Records
|
|
8
|
+
|
|
9
|
+
Capture architectural decisions as they happen during coding sessions. Instead of decisions living only in Slack threads, PR comments, or someone's memory, this skill produces structured ADR documents that live alongside the code.
|
|
10
|
+
|
|
11
|
+
## When to Activate
|
|
12
|
+
|
|
13
|
+
- User explicitly says "let's record this decision" or "ADR this"
|
|
14
|
+
- User chooses between significant alternatives (framework, library, pattern, database, API design)
|
|
15
|
+
- User says "we decided to..." or "the reason we're doing X instead of Y is..."
|
|
16
|
+
- User asks "why did we choose X?" (read existing ADRs)
|
|
17
|
+
- During planning phases when architectural trade-offs are discussed
|
|
18
|
+
|
|
19
|
+
## ADR Format
|
|
20
|
+
|
|
21
|
+
Use the lightweight ADR format proposed by Michael Nygard, adapted for AI-assisted development:
|
|
22
|
+
|
|
23
|
+
```markdown
|
|
24
|
+
# ADR-NNNN: [Decision Title]
|
|
25
|
+
|
|
26
|
+
**Date**: YYYY-MM-DD
|
|
27
|
+
**Status**: proposed | accepted | deprecated | superseded by ADR-NNNN
|
|
28
|
+
**Deciders**: [who was involved]
|
|
29
|
+
|
|
30
|
+
## Context
|
|
31
|
+
|
|
32
|
+
What is the issue that we're seeing that is motivating this decision or change?
|
|
33
|
+
|
|
34
|
+
[2-5 sentences describing the situation, constraints, and forces at play]
|
|
35
|
+
|
|
36
|
+
## Decision
|
|
37
|
+
|
|
38
|
+
What is the change that we're proposing and/or doing?
|
|
39
|
+
|
|
40
|
+
[1-3 sentences stating the decision clearly]
|
|
41
|
+
|
|
42
|
+
## Alternatives Considered
|
|
43
|
+
|
|
44
|
+
### Alternative 1: [Name]
|
|
45
|
+
- **Pros**: [benefits]
|
|
46
|
+
- **Cons**: [drawbacks]
|
|
47
|
+
- **Why not**: [specific reason this was rejected]
|
|
48
|
+
|
|
49
|
+
### Alternative 2: [Name]
|
|
50
|
+
- **Pros**: [benefits]
|
|
51
|
+
- **Cons**: [drawbacks]
|
|
52
|
+
- **Why not**: [specific reason this was rejected]
|
|
53
|
+
|
|
54
|
+
## Consequences
|
|
55
|
+
|
|
56
|
+
What becomes easier or more difficult to do because of this change?
|
|
57
|
+
|
|
58
|
+
### Positive
|
|
59
|
+
- [benefit 1]
|
|
60
|
+
- [benefit 2]
|
|
61
|
+
|
|
62
|
+
### Negative
|
|
63
|
+
- [trade-off 1]
|
|
64
|
+
- [trade-off 2]
|
|
65
|
+
|
|
66
|
+
### Risks
|
|
67
|
+
- [risk and mitigation]
|
|
68
|
+
```
|
|
69
|
+
|
|
70
|
+
## Workflow
|
|
71
|
+
|
|
72
|
+
### Capturing a New ADR
|
|
73
|
+
|
|
74
|
+
When a decision moment is detected:
|
|
75
|
+
|
|
76
|
+
1. **Initialize (first time only)** — if `docs/adr/` does not exist, ask the user for confirmation before creating the directory, a `README.md` seeded with the index table header (see ADR Index Format below), and a blank `template.md` for manual use. Do not create files without explicit consent.
|
|
77
|
+
2. **Identify the decision** — extract the core architectural choice being made
|
|
78
|
+
3. **Gather context** — what problem prompted this? What constraints exist?
|
|
79
|
+
4. **Document alternatives** — what other options were considered? Why were they rejected?
|
|
80
|
+
5. **State consequences** — what are the trade-offs? What becomes easier/harder?
|
|
81
|
+
6. **Assign a number** — scan existing ADRs in `docs/adr/` and increment
|
|
82
|
+
7. **Confirm and write** — present the draft ADR to the user for review. Only write to `docs/adr/NNNN-decision-title.md` after explicit approval. If the user declines, discard the draft without writing any files.
|
|
83
|
+
8. **Update the index** — append to `docs/adr/README.md`
|
|
84
|
+
|
|
85
|
+
### Reading Existing ADRs
|
|
86
|
+
|
|
87
|
+
When a user asks "why did we choose X?":
|
|
88
|
+
|
|
89
|
+
1. Check if `docs/adr/` exists — if not, respond: "No ADRs found in this project. Would you like to start recording architectural decisions?"
|
|
90
|
+
2. If it exists, scan `docs/adr/README.md` index for relevant entries
|
|
91
|
+
3. Read matching ADR files and present the Context and Decision sections
|
|
92
|
+
4. If no match is found, respond: "No ADR found for that decision. Would you like to record one now?"
|
|
93
|
+
|
|
94
|
+
### ADR Directory Structure
|
|
95
|
+
|
|
96
|
+
```
|
|
97
|
+
docs/
|
|
98
|
+
└── adr/
|
|
99
|
+
├── README.md ← index of all ADRs
|
|
100
|
+
├── 0001-use-nextjs.md
|
|
101
|
+
├── 0002-postgres-over-mongo.md
|
|
102
|
+
├── 0003-rest-over-graphql.md
|
|
103
|
+
└── template.md ← blank template for manual use
|
|
104
|
+
```
|
|
105
|
+
|
|
106
|
+
### ADR Index Format
|
|
107
|
+
|
|
108
|
+
```markdown
|
|
109
|
+
# Architecture Decision Records
|
|
110
|
+
|
|
111
|
+
| ADR | Title | Status | Date |
|
|
112
|
+
|-----|-------|--------|------|
|
|
113
|
+
| [0001](0001-use-nextjs.md) | Use Next.js as frontend framework | accepted | 2026-01-15 |
|
|
114
|
+
| [0002](0002-postgres-over-mongo.md) | PostgreSQL over MongoDB for primary datastore | accepted | 2026-01-20 |
|
|
115
|
+
| [0003](0003-rest-over-graphql.md) | REST API over GraphQL | accepted | 2026-02-01 |
|
|
116
|
+
```
|
|
117
|
+
|
|
118
|
+
## Decision Detection Signals
|
|
119
|
+
|
|
120
|
+
Watch for these patterns in conversation that indicate an architectural decision:
|
|
121
|
+
|
|
122
|
+
**Explicit signals**
|
|
123
|
+
- "Let's go with X"
|
|
124
|
+
- "We should use X instead of Y"
|
|
125
|
+
- "The trade-off is worth it because..."
|
|
126
|
+
- "Record this as an ADR"
|
|
127
|
+
|
|
128
|
+
**Implicit signals** (suggest recording an ADR — do not auto-create without user confirmation)
|
|
129
|
+
- Comparing two frameworks or libraries and reaching a conclusion
|
|
130
|
+
- Making a database schema design choice with stated rationale
|
|
131
|
+
- Choosing between architectural patterns (monolith vs microservices, REST vs GraphQL)
|
|
132
|
+
- Deciding on authentication/authorization strategy
|
|
133
|
+
- Selecting deployment infrastructure after evaluating alternatives
|
|
134
|
+
|
|
135
|
+
## What Makes a Good ADR
|
|
136
|
+
|
|
137
|
+
### Do
|
|
138
|
+
- **Be specific** — "Use Prisma ORM" not "use an ORM"
|
|
139
|
+
- **Record the why** — the rationale matters more than the what
|
|
140
|
+
- **Include rejected alternatives** — future developers need to know what was considered
|
|
141
|
+
- **State consequences honestly** — every decision has trade-offs
|
|
142
|
+
- **Keep it short** — an ADR should be readable in 2 minutes
|
|
143
|
+
- **Use present tense** — "We use X" not "We will use X"
|
|
144
|
+
|
|
145
|
+
### Don't
|
|
146
|
+
- Record trivial decisions — variable naming or formatting choices don't need ADRs
|
|
147
|
+
- Write essays — if the context section exceeds 10 lines, it's too long
|
|
148
|
+
- Omit alternatives — "we just picked it" is not a valid rationale
|
|
149
|
+
- Backfill without marking it — if recording a past decision, note the original date
|
|
150
|
+
- Let ADRs go stale — superseded decisions should reference their replacement
|
|
151
|
+
|
|
152
|
+
## ADR Lifecycle
|
|
153
|
+
|
|
154
|
+
```
|
|
155
|
+
proposed → accepted → [deprecated | superseded by ADR-NNNN]
|
|
156
|
+
```
|
|
157
|
+
|
|
158
|
+
- **proposed**: decision is under discussion, not yet committed
|
|
159
|
+
- **accepted**: decision is in effect and being followed
|
|
160
|
+
- **deprecated**: decision is no longer relevant (e.g., feature removed)
|
|
161
|
+
- **superseded**: a newer ADR replaces this one (always link the replacement)
|
|
162
|
+
|
|
163
|
+
## Categories of Decisions Worth Recording
|
|
164
|
+
|
|
165
|
+
| Category | Examples |
|
|
166
|
+
|----------|---------|
|
|
167
|
+
| **Technology choices** | Framework, language, database, cloud provider |
|
|
168
|
+
| **Architecture patterns** | Monolith vs microservices, event-driven, CQRS |
|
|
169
|
+
| **API design** | REST vs GraphQL, versioning strategy, auth mechanism |
|
|
170
|
+
| **Data modeling** | Schema design, normalization decisions, caching strategy |
|
|
171
|
+
| **Infrastructure** | Deployment model, CI/CD pipeline, monitoring stack |
|
|
172
|
+
| **Security** | Auth strategy, encryption approach, secret management |
|
|
173
|
+
| **Testing** | Test framework, coverage targets, E2E vs integration balance |
|
|
174
|
+
| **Process** | Branching strategy, review process, release cadence |
|
|
175
|
+
|
|
176
|
+
## Integration with Other Skills
|
|
177
|
+
|
|
178
|
+
- **Planner agent**: when the planner proposes architecture changes, suggest creating an ADR
|
|
179
|
+
- **Code reviewer agent**: flag PRs that introduce architectural changes without a corresponding ADR
|