@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.
Files changed (594) hide show
  1. package/.agent/agents/architect.md +211 -211
  2. package/.agent/agents/build-error-resolver.md +114 -114
  3. package/.agent/agents/chief-of-staff.md +151 -151
  4. package/.agent/agents/code-reviewer.md +237 -237
  5. package/.agent/agents/cpp-build-resolver.md +90 -90
  6. package/.agent/agents/cpp-reviewer.md +72 -72
  7. package/.agent/agents/csharp-reviewer.md +101 -0
  8. package/.agent/agents/dart-build-resolver.md +201 -0
  9. package/.agent/agents/database-reviewer.md +91 -91
  10. package/.agent/agents/doc-updater.md +107 -107
  11. package/.agent/agents/docs-lookup.md +68 -68
  12. package/.agent/agents/e2e-runner.md +107 -107
  13. package/.agent/agents/flutter-reviewer.md +243 -243
  14. package/.agent/agents/gan-evaluator.md +209 -0
  15. package/.agent/agents/gan-generator.md +131 -0
  16. package/.agent/agents/gan-planner.md +99 -0
  17. package/.agent/agents/go-build-resolver.md +94 -94
  18. package/.agent/agents/go-reviewer.md +76 -76
  19. package/.agent/agents/harness-optimizer.md +35 -35
  20. package/.agent/agents/healthcare-reviewer.md +83 -0
  21. package/.agent/agents/java-build-resolver.md +153 -153
  22. package/.agent/agents/java-reviewer.md +92 -92
  23. package/.agent/agents/kotlin-build-resolver.md +118 -118
  24. package/.agent/agents/kotlin-reviewer.md +159 -159
  25. package/.agent/agents/loop-operator.md +36 -36
  26. package/.agent/agents/opensource-forker.md +198 -0
  27. package/.agent/agents/opensource-packager.md +249 -0
  28. package/.agent/agents/opensource-sanitizer.md +188 -0
  29. package/.agent/agents/performance-optimizer.md +392 -133
  30. package/.agent/agents/personas/athena-agent/agent.json +10 -0
  31. package/.agent/agents/personas/athena-agent/athena-backend-logic-architecture-profile.md +189 -0
  32. package/.agent/agents/personas/athena-agent/context-files/agents.md +55 -0
  33. package/.agent/agents/personas/athena-agent/context-files/identity.md +23 -0
  34. package/.agent/agents/personas/athena-agent/context-files/soul.md +51 -0
  35. package/.agent/agents/personas/athena-agent/context-files/user-predefined.md +15 -0
  36. package/.agent/agents/personas/athena-agent/user-context-files/system/bootstrap.md +37 -0
  37. package/.agent/agents/personas/athena-agent/user-context-files/system/user.md +45 -0
  38. package/.agent/agents/personas/da-vinci-agent/agent.json +10 -0
  39. package/.agent/agents/personas/da-vinci-agent/context-files/agents.md +55 -0
  40. package/.agent/agents/personas/da-vinci-agent/context-files/identity.md +23 -0
  41. package/.agent/agents/personas/da-vinci-agent/context-files/soul.md +51 -0
  42. package/.agent/agents/personas/da-vinci-agent/context-files/user-predefined.md +15 -0
  43. package/.agent/agents/personas/da-vinci-agent/da-vinci-frontend-ui-ux-design-profile.md +189 -0
  44. package/.agent/agents/personas/da-vinci-agent/user-context-files/system/bootstrap.md +37 -0
  45. package/.agent/agents/personas/da-vinci-agent/user-context-files/system/user.md +45 -0
  46. package/.agent/agents/personas/duong-tang-agent/agent.json +10 -0
  47. package/.agent/agents/personas/duong-tang-agent/context-files/agents.md +55 -0
  48. package/.agent/agents/personas/duong-tang-agent/context-files/identity.md +23 -0
  49. package/.agent/agents/personas/duong-tang-agent/context-files/soul.md +51 -0
  50. package/.agent/agents/personas/duong-tang-agent/context-files/user-predefined.md +15 -0
  51. package/.agent/agents/personas/duong-tang-agent/tang-monk-quality-testing-documentation-profile.md +189 -0
  52. package/.agent/agents/personas/duong-tang-agent/user-context-files/system/bootstrap.md +37 -0
  53. package/.agent/agents/personas/duong-tang-agent/user-context-files/system/user.md +45 -0
  54. package/.agent/agents/personas/gia-cat-luong-agent/agent.json +10 -0
  55. package/.agent/agents/personas/gia-cat-luong-agent/context-files/agents.md +55 -0
  56. package/.agent/agents/personas/gia-cat-luong-agent/context-files/identity.md +23 -0
  57. package/.agent/agents/personas/gia-cat-luong-agent/context-files/soul.md +51 -0
  58. package/.agent/agents/personas/gia-cat-luong-agent/context-files/user-predefined.md +15 -0
  59. package/.agent/agents/personas/gia-cat-luong-agent/kongming-research-strategy-analysis-profile.md +189 -0
  60. package/.agent/agents/personas/gia-cat-luong-agent/user-context-files/system/bootstrap.md +37 -0
  61. package/.agent/agents/personas/gia-cat-luong-agent/user-context-files/system/user.md +45 -0
  62. package/.agent/agents/personas/mihata-agent/agent.json +10 -0
  63. package/.agent/agents/personas/mihata-agent/context-files/agents.md +55 -0
  64. package/.agent/agents/personas/mihata-agent/context-files/identity.md +23 -0
  65. package/.agent/agents/personas/mihata-agent/context-files/soul.md +51 -0
  66. package/.agent/agents/personas/mihata-agent/context-files/user-predefined.md +15 -0
  67. package/.agent/agents/personas/mihata-agent/mihata-multi-agent-orchestration-profile.md +189 -0
  68. package/.agent/agents/personas/mihata-agent/user-context-files/system/bootstrap.md +37 -0
  69. package/.agent/agents/personas/mihata-agent/user-context-files/system/user.md +45 -0
  70. package/.agent/agents/personas/tesla-agent/agent.json +10 -0
  71. package/.agent/agents/personas/tesla-agent/context-files/agents.md +55 -0
  72. package/.agent/agents/personas/tesla-agent/context-files/identity.md +23 -0
  73. package/.agent/agents/personas/tesla-agent/context-files/soul.md +51 -0
  74. package/.agent/agents/personas/tesla-agent/context-files/user-predefined.md +15 -0
  75. package/.agent/agents/personas/tesla-agent/tesla-fullstack-system-optimization-profile.md +189 -0
  76. package/.agent/agents/personas/tesla-agent/user-context-files/system/bootstrap.md +37 -0
  77. package/.agent/agents/personas/tesla-agent/user-context-files/system/user.md +45 -0
  78. package/.agent/agents/personas/tu-ma-y-agent/agent.json +10 -0
  79. package/.agent/agents/personas/tu-ma-y-agent/context-files/agents.md +55 -0
  80. package/.agent/agents/personas/tu-ma-y-agent/context-files/identity.md +23 -0
  81. package/.agent/agents/personas/tu-ma-y-agent/context-files/soul.md +51 -0
  82. package/.agent/agents/personas/tu-ma-y-agent/context-files/user-predefined.md +15 -0
  83. package/.agent/agents/personas/tu-ma-y-agent/simayi-feasibility-risk-control-profile.md +189 -0
  84. package/.agent/agents/personas/tu-ma-y-agent/user-context-files/system/bootstrap.md +37 -0
  85. package/.agent/agents/personas/tu-ma-y-agent/user-context-files/system/user.md +45 -0
  86. package/.agent/agents/personas/venti-agent/agent.json +10 -0
  87. package/.agent/agents/personas/venti-agent/context-files/agents.md +55 -0
  88. package/.agent/agents/personas/venti-agent/context-files/identity.md +23 -0
  89. package/.agent/agents/personas/venti-agent/context-files/soul.md +51 -0
  90. package/.agent/agents/personas/venti-agent/context-files/user-predefined.md +15 -0
  91. package/.agent/agents/personas/venti-agent/user-context-files/system/bootstrap.md +37 -0
  92. package/.agent/agents/personas/venti-agent/user-context-files/system/user.md +45 -0
  93. package/.agent/agents/personas/venti-agent/venti-learning-communication-mentoring-profile.md +189 -0
  94. package/.agent/agents/planner.md +212 -212
  95. package/.agent/agents/python-reviewer.md +98 -98
  96. package/.agent/agents/pytorch-build-resolver.md +120 -120
  97. package/.agent/agents/refactor-cleaner.md +85 -85
  98. package/.agent/agents/rust-build-resolver.md +148 -148
  99. package/.agent/agents/rust-reviewer.md +94 -94
  100. package/.agent/agents/security-reviewer.md +108 -108
  101. package/.agent/agents/tdd-guide.md +91 -91
  102. package/.agent/agents/typescript-reviewer.md +112 -112
  103. package/.agent/contexts/dev.md +20 -0
  104. package/.agent/contexts/research.md +26 -0
  105. package/.agent/contexts/review.md +22 -0
  106. package/.agent/hooks/hooks.json +395 -0
  107. package/.agent/hooks/readme.md +222 -0
  108. package/.agent/mcp-configs/mcp-servers.json +181 -0
  109. package/.agent/rules/common/agents.md +50 -0
  110. package/.agent/rules/common/code-review.md +124 -0
  111. package/.agent/rules/common/coding-style.md +48 -0
  112. package/.agent/rules/common/development-workflow.md +44 -0
  113. package/.agent/rules/common/git-workflow.md +24 -0
  114. package/.agent/rules/common/hooks.md +30 -0
  115. package/.agent/rules/common/patterns.md +31 -0
  116. package/.agent/rules/common/performance.md +55 -0
  117. package/.agent/rules/common/security.md +29 -0
  118. package/.agent/rules/common/testing.md +29 -0
  119. package/.agent/rules/cpp/coding-style.md +44 -0
  120. package/.agent/rules/cpp/hooks.md +39 -0
  121. package/.agent/rules/cpp/patterns.md +51 -0
  122. package/.agent/rules/cpp/security.md +51 -0
  123. package/.agent/rules/cpp/testing.md +44 -0
  124. package/.agent/rules/csharp/coding-style.md +72 -0
  125. package/.agent/rules/csharp/hooks.md +25 -0
  126. package/.agent/rules/csharp/patterns.md +50 -0
  127. package/.agent/rules/csharp/security.md +58 -0
  128. package/.agent/rules/csharp/testing.md +46 -0
  129. package/.agent/rules/dart/coding-style.md +159 -0
  130. package/.agent/rules/dart/hooks.md +66 -0
  131. package/.agent/rules/dart/patterns.md +261 -0
  132. package/.agent/rules/dart/security.md +135 -0
  133. package/.agent/rules/dart/testing.md +215 -0
  134. package/.agent/rules/golang/coding-style.md +32 -0
  135. package/.agent/rules/golang/hooks.md +17 -0
  136. package/.agent/rules/golang/patterns.md +45 -0
  137. package/.agent/rules/golang/security.md +34 -0
  138. package/.agent/rules/golang/testing.md +31 -0
  139. package/.agent/rules/java/coding-style.md +114 -0
  140. package/.agent/rules/java/hooks.md +18 -0
  141. package/.agent/rules/java/patterns.md +146 -0
  142. package/.agent/rules/java/security.md +100 -0
  143. package/.agent/rules/java/testing.md +131 -0
  144. package/.agent/rules/kotlin/coding-style.md +86 -0
  145. package/.agent/rules/kotlin/hooks.md +17 -0
  146. package/.agent/rules/kotlin/patterns.md +146 -0
  147. package/.agent/rules/kotlin/security.md +82 -0
  148. package/.agent/rules/kotlin/testing.md +128 -0
  149. package/.agent/rules/perl/coding-style.md +46 -0
  150. package/.agent/rules/perl/hooks.md +22 -0
  151. package/.agent/rules/perl/patterns.md +76 -0
  152. package/.agent/rules/perl/security.md +69 -0
  153. package/.agent/rules/perl/testing.md +54 -0
  154. package/.agent/rules/php/coding-style.md +40 -0
  155. package/.agent/rules/php/hooks.md +24 -0
  156. package/.agent/rules/php/patterns.md +33 -0
  157. package/.agent/rules/php/security.md +37 -0
  158. package/.agent/rules/php/testing.md +39 -0
  159. package/.agent/rules/python/coding-style.md +42 -0
  160. package/.agent/rules/python/hooks.md +19 -0
  161. package/.agent/rules/python/patterns.md +39 -0
  162. package/.agent/rules/python/security.md +30 -0
  163. package/.agent/rules/python/testing.md +38 -0
  164. package/.agent/rules/readme.md +111 -0
  165. package/.agent/rules/rust/coding-style.md +151 -0
  166. package/.agent/rules/rust/hooks.md +16 -0
  167. package/.agent/rules/rust/patterns.md +168 -0
  168. package/.agent/rules/rust/security.md +141 -0
  169. package/.agent/rules/rust/testing.md +154 -0
  170. package/.agent/rules/swift/coding-style.md +47 -0
  171. package/.agent/rules/swift/hooks.md +20 -0
  172. package/.agent/rules/swift/patterns.md +66 -0
  173. package/.agent/rules/swift/security.md +33 -0
  174. package/.agent/rules/swift/testing.md +45 -0
  175. package/.agent/rules/typescript/coding-style.md +199 -0
  176. package/.agent/rules/typescript/hooks.md +22 -0
  177. package/.agent/rules/typescript/patterns.md +52 -0
  178. package/.agent/rules/typescript/security.md +28 -0
  179. package/.agent/rules/typescript/testing.md +18 -0
  180. package/.agent/rules/web/coding-style.md +96 -0
  181. package/.agent/rules/web/design-quality.md +63 -0
  182. package/.agent/rules/web/hooks.md +120 -0
  183. package/.agent/rules/web/patterns.md +79 -0
  184. package/.agent/rules/web/performance.md +64 -0
  185. package/.agent/rules/web/security.md +57 -0
  186. package/.agent/rules/web/testing.md +55 -0
  187. package/.agent/rules/zh/agents.md +50 -0
  188. package/.agent/rules/zh/code-review.md +124 -0
  189. package/.agent/rules/zh/coding-style.md +48 -0
  190. package/.agent/rules/zh/development-workflow.md +44 -0
  191. package/.agent/rules/zh/git-workflow.md +24 -0
  192. package/.agent/rules/zh/hooks.md +30 -0
  193. package/.agent/rules/zh/patterns.md +31 -0
  194. package/.agent/rules/zh/performance.md +55 -0
  195. package/.agent/rules/zh/readme.md +108 -0
  196. package/.agent/rules/zh/security.md +29 -0
  197. package/.agent/rules/zh/testing.md +29 -0
  198. package/.agent/skills/agent-eval/SKILL.md +145 -0
  199. package/.agent/skills/agent-harness-construction/SKILL.md +73 -0
  200. package/.agent/skills/agent-payment-x402/SKILL.md +178 -0
  201. package/.agent/skills/agentic-engineering/SKILL.md +63 -0
  202. package/.agent/skills/ai-first-engineering/SKILL.md +51 -0
  203. package/.agent/skills/ai-regression-testing/SKILL.md +385 -0
  204. package/.agent/skills/android-clean-architecture/SKILL.md +339 -0
  205. package/.agent/skills/api-design/SKILL.md +523 -0
  206. package/.agent/skills/architecture-decision-records/SKILL.md +179 -0
  207. package/.agent/skills/article-writing/SKILL.md +79 -0
  208. package/.agent/skills/autonomous-agent-harness/SKILL.md +267 -0
  209. package/.agent/skills/autonomous-loops/SKILL.md +610 -0
  210. package/.agent/skills/backend-patterns/SKILL.md +598 -0
  211. package/.agent/skills/benchmark/SKILL.md +93 -0
  212. package/.agent/skills/blueprint/SKILL.md +105 -0
  213. package/.agent/skills/brand-voice/SKILL.md +97 -0
  214. package/.agent/skills/brand-voice/references/voice-profile-schema.md +55 -0
  215. package/.agent/skills/browser-qa/SKILL.md +87 -0
  216. package/.agent/skills/bun-runtime/SKILL.md +84 -0
  217. package/.agent/skills/canary-watch/SKILL.md +99 -0
  218. package/.agent/skills/carrier-relationship-management/SKILL.md +212 -0
  219. package/.agent/skills/ck/SKILL.md +147 -0
  220. package/.agent/skills/ck/commands/forget.mjs +44 -0
  221. package/.agent/skills/ck/commands/info.mjs +24 -0
  222. package/.agent/skills/ck/commands/init.mjs +143 -0
  223. package/.agent/skills/ck/commands/list.mjs +40 -0
  224. package/.agent/skills/ck/commands/migrate.mjs +202 -0
  225. package/.agent/skills/ck/commands/resume.mjs +36 -0
  226. package/.agent/skills/ck/commands/save.mjs +210 -0
  227. package/.agent/skills/ck/commands/shared.mjs +387 -0
  228. package/.agent/skills/ck/hooks/session-start.mjs +224 -0
  229. package/.agent/skills/claude-api/SKILL.md +337 -0
  230. package/.agent/skills/claude-devfleet/SKILL.md +103 -0
  231. package/.agent/skills/click-path-audit/SKILL.md +244 -0
  232. package/.agent/skills/clickhouse-io/SKILL.md +439 -0
  233. package/.agent/skills/codebase-onboarding/SKILL.md +233 -0
  234. package/.agent/skills/coding-standards/SKILL.md +530 -0
  235. package/.agent/skills/compose-multiplatform-patterns/SKILL.md +299 -0
  236. package/.agent/skills/configure-ecc/SKILL.md +367 -0
  237. package/.agent/skills/connections-optimizer/SKILL.md +189 -0
  238. package/.agent/skills/content-engine/SKILL.md +131 -0
  239. package/.agent/skills/content-hash-cache-pattern/SKILL.md +161 -0
  240. package/.agent/skills/context-budget/SKILL.md +135 -0
  241. package/.agent/skills/continuous-agent-loop/SKILL.md +45 -0
  242. package/.agent/skills/continuous-learning/SKILL.md +119 -0
  243. package/.agent/skills/continuous-learning/config.json +18 -0
  244. package/.agent/skills/continuous-learning/evaluate-session.sh +69 -0
  245. package/.agent/skills/continuous-learning-v2/SKILL.md +365 -0
  246. package/.agent/skills/continuous-learning-v2/agents/observer-loop.sh +271 -0
  247. package/.agent/skills/continuous-learning-v2/agents/observer.md +198 -0
  248. package/.agent/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
  249. package/.agent/skills/continuous-learning-v2/agents/start-observer.sh +244 -0
  250. package/.agent/skills/continuous-learning-v2/config.json +8 -0
  251. package/.agent/skills/continuous-learning-v2/hooks/observe.sh +428 -0
  252. package/.agent/skills/continuous-learning-v2/scripts/detect-project.sh +228 -0
  253. package/.agent/skills/continuous-learning-v2/scripts/instinct-cli.py +1426 -0
  254. package/.agent/skills/continuous-learning-v2/scripts/test-parse-instinct.py +984 -0
  255. package/.agent/skills/cost-aware-llm-pipeline/SKILL.md +183 -0
  256. package/.agent/skills/cpp-coding-standards/SKILL.md +723 -0
  257. package/.agent/skills/cpp-testing/SKILL.md +324 -0
  258. package/.agent/skills/crosspost/SKILL.md +111 -0
  259. package/.agent/skills/csharp-testing/SKILL.md +321 -0
  260. package/.agent/skills/customer-billing-ops/SKILL.md +140 -0
  261. package/.agent/skills/customs-trade-compliance/SKILL.md +263 -0
  262. package/.agent/skills/dart-flutter-patterns/SKILL.md +563 -0
  263. package/.agent/skills/data-scraper-agent/SKILL.md +764 -0
  264. package/.agent/skills/database-migrations/SKILL.md +429 -0
  265. package/.agent/skills/deep-research/SKILL.md +155 -0
  266. package/.agent/skills/deployment-patterns/SKILL.md +427 -0
  267. package/.agent/skills/design-system/SKILL.md +82 -0
  268. package/.agent/skills/django-patterns/SKILL.md +734 -0
  269. package/.agent/skills/django-security/SKILL.md +593 -0
  270. package/.agent/skills/django-tdd/SKILL.md +729 -0
  271. package/.agent/skills/django-verification/SKILL.md +469 -0
  272. package/.agent/skills/dmux-workflows/SKILL.md +191 -0
  273. package/.agent/skills/docker-patterns/SKILL.md +364 -0
  274. package/.agent/skills/documentation-lookup/SKILL.md +90 -0
  275. package/.agent/skills/dotnet-patterns/SKILL.md +321 -0
  276. package/.agent/skills/e2e-testing/SKILL.md +326 -0
  277. package/.agent/skills/energy-procurement/SKILL.md +228 -0
  278. package/.agent/skills/enterprise-agent-ops/SKILL.md +50 -0
  279. package/.agent/skills/eval-harness/SKILL.md +270 -0
  280. package/.agent/skills/exa-search/SKILL.md +103 -0
  281. package/.agent/skills/fal-ai-media/SKILL.md +284 -0
  282. package/.agent/skills/flutter-dart-code-review/SKILL.md +435 -0
  283. package/.agent/skills/foundation-models-on-device/SKILL.md +243 -0
  284. package/.agent/skills/frontend-patterns/SKILL.md +642 -0
  285. package/.agent/skills/frontend-slides/SKILL.md +184 -0
  286. package/.agent/skills/frontend-slides/style-presets.md +330 -0
  287. package/.agent/skills/gan-style-harness/SKILL.md +278 -0
  288. package/.agent/skills/git-workflow/SKILL.md +715 -0
  289. package/.agent/skills/golang-patterns/SKILL.md +674 -0
  290. package/.agent/skills/golang-testing/SKILL.md +720 -0
  291. package/.agent/skills/google-workspace-ops/SKILL.md +95 -0
  292. package/.agent/skills/healthcare-cdss-patterns/SKILL.md +245 -0
  293. package/.agent/skills/healthcare-emr-patterns/SKILL.md +159 -0
  294. package/.agent/skills/healthcare-eval-harness/SKILL.md +207 -0
  295. package/.agent/skills/healthcare-phi-compliance/SKILL.md +145 -0
  296. package/.agent/skills/hexagonal-architecture/SKILL.md +276 -0
  297. package/.agent/skills/inventory-demand-planning/SKILL.md +247 -0
  298. package/.agent/skills/investor-materials/SKILL.md +96 -0
  299. package/.agent/skills/investor-outreach/SKILL.md +91 -0
  300. package/.agent/skills/iterative-retrieval/SKILL.md +211 -0
  301. package/.agent/skills/java-coding-standards/SKILL.md +147 -0
  302. package/.agent/skills/jira-integration/SKILL.md +293 -0
  303. package/.agent/skills/jpa-patterns/SKILL.md +151 -0
  304. package/.agent/skills/kotlin-coroutines-flows/SKILL.md +284 -0
  305. package/.agent/skills/kotlin-exposed-patterns/SKILL.md +719 -0
  306. package/.agent/skills/kotlin-ktor-patterns/SKILL.md +689 -0
  307. package/.agent/skills/kotlin-patterns/SKILL.md +711 -0
  308. package/.agent/skills/kotlin-testing/SKILL.md +824 -0
  309. package/.agent/skills/laravel-patterns/SKILL.md +415 -0
  310. package/.agent/skills/laravel-plugin-discovery/SKILL.md +229 -0
  311. package/.agent/skills/laravel-security/SKILL.md +285 -0
  312. package/.agent/skills/laravel-tdd/SKILL.md +283 -0
  313. package/.agent/skills/laravel-verification/SKILL.md +179 -0
  314. package/.agent/skills/lead-intelligence/SKILL.md +321 -0
  315. package/.agent/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
  316. package/.agent/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
  317. package/.agent/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
  318. package/.agent/skills/lead-intelligence/agents/signal-scorer.md +60 -0
  319. package/.agent/skills/liquid-glass-design/SKILL.md +279 -0
  320. package/.agent/skills/logistics-exception-management/SKILL.md +222 -0
  321. package/.agent/skills/manim-video/SKILL.md +89 -0
  322. package/.agent/skills/manim-video/assets/network-graph-scene.py +52 -0
  323. package/.agent/skills/market-research/SKILL.md +75 -0
  324. package/.agent/skills/mcp-builder/SKILL.md +173 -113
  325. package/.agent/skills/mcp-builder/license.txt +202 -0
  326. package/.agent/skills/mcp-builder/reference/evaluation.md +602 -0
  327. package/.agent/skills/mcp-builder/reference/mcp-best-practices.md +249 -0
  328. package/.agent/skills/mcp-builder/reference/node-mcp-server.md +970 -0
  329. package/.agent/skills/mcp-builder/reference/python-mcp-server.md +719 -0
  330. package/.agent/skills/mcp-builder/scripts/connections.py +151 -0
  331. package/.agent/skills/mcp-builder/scripts/evaluation.py +373 -0
  332. package/.agent/skills/mcp-builder/scripts/example-evaluation.xml +22 -0
  333. package/.agent/skills/mcp-builder/scripts/requirements.txt +2 -0
  334. package/.agent/skills/mcp-server-patterns/SKILL.md +67 -0
  335. package/.agent/skills/nanoclaw-repl/SKILL.md +33 -0
  336. package/.agent/skills/nestjs-patterns/SKILL.md +230 -0
  337. package/.agent/skills/nextjs-turbopack/SKILL.md +44 -0
  338. package/.agent/skills/nutrient-document-processing/SKILL.md +167 -0
  339. package/.agent/skills/nuxt4-patterns/SKILL.md +100 -0
  340. package/.agent/skills/openclaw-persona-forge/SKILL.md +296 -0
  341. package/.agent/skills/openclaw-persona-forge/gacha.py +224 -0
  342. package/.agent/skills/openclaw-persona-forge/gacha.sh +5 -0
  343. package/.agent/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
  344. package/.agent/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
  345. package/.agent/skills/openclaw-persona-forge/references/error-handling.md +53 -0
  346. package/.agent/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
  347. package/.agent/skills/openclaw-persona-forge/references/naming-system.md +39 -0
  348. package/.agent/skills/openclaw-persona-forge/references/output-template.md +166 -0
  349. package/.agent/skills/opensource-pipeline/SKILL.md +255 -0
  350. package/.agent/skills/perl-patterns/SKILL.md +504 -0
  351. package/.agent/skills/perl-security/SKILL.md +503 -0
  352. package/.agent/skills/perl-testing/SKILL.md +475 -0
  353. package/.agent/skills/plankton-code-quality/SKILL.md +236 -0
  354. package/.agent/skills/postgres-patterns/SKILL.md +147 -0
  355. package/.agent/skills/product-lens/SKILL.md +85 -0
  356. package/.agent/skills/production-scheduling/SKILL.md +238 -0
  357. package/.agent/skills/project-flow-ops/SKILL.md +111 -0
  358. package/.agent/skills/project-guidelines-example/SKILL.md +349 -0
  359. package/.agent/skills/prompt-optimizer/SKILL.md +397 -0
  360. package/.agent/skills/python-patterns/SKILL.md +622 -313
  361. package/.agent/skills/python-testing/SKILL.md +816 -0
  362. package/.agent/skills/pytorch-patterns/SKILL.md +396 -0
  363. package/.agent/skills/quality-nonconformance/SKILL.md +260 -0
  364. package/.agent/skills/ralphinho-rfc-pipeline/SKILL.md +67 -0
  365. package/.agent/skills/regex-vs-llm-structured-text/SKILL.md +220 -0
  366. package/.agent/skills/remotion-video-creation/SKILL.md +43 -0
  367. package/.agent/skills/remotion-video-creation/rules/3d.md +86 -0
  368. package/.agent/skills/remotion-video-creation/rules/animations.md +29 -0
  369. package/.agent/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
  370. package/.agent/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
  371. package/.agent/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
  372. package/.agent/skills/remotion-video-creation/rules/assets.md +78 -0
  373. package/.agent/skills/remotion-video-creation/rules/audio.md +172 -0
  374. package/.agent/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
  375. package/.agent/skills/remotion-video-creation/rules/can-decode.md +75 -0
  376. package/.agent/skills/remotion-video-creation/rules/charts.md +58 -0
  377. package/.agent/skills/remotion-video-creation/rules/compositions.md +146 -0
  378. package/.agent/skills/remotion-video-creation/rules/display-captions.md +126 -0
  379. package/.agent/skills/remotion-video-creation/rules/extract-frames.md +229 -0
  380. package/.agent/skills/remotion-video-creation/rules/fonts.md +152 -0
  381. package/.agent/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
  382. package/.agent/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
  383. package/.agent/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
  384. package/.agent/skills/remotion-video-creation/rules/gifs.md +138 -0
  385. package/.agent/skills/remotion-video-creation/rules/images.md +130 -0
  386. package/.agent/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
  387. package/.agent/skills/remotion-video-creation/rules/lottie.md +67 -0
  388. package/.agent/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
  389. package/.agent/skills/remotion-video-creation/rules/measuring-text.md +143 -0
  390. package/.agent/skills/remotion-video-creation/rules/sequencing.md +106 -0
  391. package/.agent/skills/remotion-video-creation/rules/tailwind.md +11 -0
  392. package/.agent/skills/remotion-video-creation/rules/text-animations.md +20 -0
  393. package/.agent/skills/remotion-video-creation/rules/timing.md +179 -0
  394. package/.agent/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
  395. package/.agent/skills/remotion-video-creation/rules/transitions.md +122 -0
  396. package/.agent/skills/remotion-video-creation/rules/trimming.md +52 -0
  397. package/.agent/skills/remotion-video-creation/rules/videos.md +171 -0
  398. package/.agent/skills/repo-scan/SKILL.md +78 -0
  399. package/.agent/skills/returns-reverse-logistics/SKILL.md +240 -0
  400. package/.agent/skills/rules-distill/SKILL.md +264 -0
  401. package/.agent/skills/rules-distill/scripts/scan-rules.sh +58 -0
  402. package/.agent/skills/rules-distill/scripts/scan-skills.sh +129 -0
  403. package/.agent/skills/rust-patterns/SKILL.md +499 -0
  404. package/.agent/skills/rust-testing/SKILL.md +500 -0
  405. package/.agent/skills/safety-guard/SKILL.md +75 -0
  406. package/.agent/skills/santa-method/SKILL.md +306 -0
  407. package/.agent/skills/search-first/SKILL.md +161 -0
  408. package/.agent/skills/security-review/SKILL.md +495 -0
  409. package/.agent/skills/security-review/cloud-infrastructure-security.md +361 -0
  410. package/.agent/skills/security-scan/SKILL.md +165 -0
  411. package/.agent/skills/skill-comply/SKILL.md +58 -0
  412. package/.agent/skills/skill-comply/fixtures/compliant-trace.jsonl +5 -0
  413. package/.agent/skills/skill-comply/fixtures/noncompliant-trace.jsonl +3 -0
  414. package/.agent/skills/skill-comply/fixtures/tdd-spec.yaml +44 -0
  415. package/.agent/skills/skill-comply/prompts/classifier.md +24 -0
  416. package/.agent/skills/skill-comply/prompts/scenario-generator.md +62 -0
  417. package/.agent/skills/skill-comply/prompts/spec-generator.md +42 -0
  418. package/.agent/skills/skill-comply/pyproject.toml +15 -0
  419. package/.agent/skills/skill-comply/scripts/classifier.py +85 -0
  420. package/.agent/skills/skill-comply/scripts/grader.py +122 -0
  421. package/.agent/skills/skill-comply/scripts/init.py +0 -0
  422. package/.agent/skills/skill-comply/scripts/parser.py +107 -0
  423. package/.agent/skills/skill-comply/scripts/report.py +170 -0
  424. package/.agent/skills/skill-comply/scripts/run.py +127 -0
  425. package/.agent/skills/skill-comply/scripts/runner.py +161 -0
  426. package/.agent/skills/skill-comply/scripts/scenario-generator.py +70 -0
  427. package/.agent/skills/skill-comply/scripts/spec-generator.py +72 -0
  428. package/.agent/skills/skill-comply/scripts/utils.py +13 -0
  429. package/.agent/skills/skill-comply/tests/test-grader.py +137 -0
  430. package/.agent/skills/skill-comply/tests/test-parser.py +90 -0
  431. package/.agent/skills/skill-creator/SKILL.md +485 -0
  432. package/.agent/skills/skill-creator/agents/analyzer.md +274 -0
  433. package/.agent/skills/skill-creator/agents/comparator.md +202 -0
  434. package/.agent/skills/skill-creator/agents/grader.md +223 -0
  435. package/.agent/skills/skill-creator/assets/eval-review.html +146 -0
  436. package/.agent/skills/skill-creator/eval-viewer/generate-review.py +471 -0
  437. package/.agent/skills/skill-creator/eval-viewer/viewer.html +1325 -0
  438. package/.agent/skills/skill-creator/license.txt +202 -0
  439. package/.agent/skills/skill-creator/references/schemas.md +430 -0
  440. package/.agent/skills/skill-creator/scripts/aggregate-benchmark.py +401 -0
  441. package/.agent/skills/skill-creator/scripts/generate-report.py +326 -0
  442. package/.agent/skills/skill-creator/scripts/improve-description.py +247 -0
  443. package/.agent/skills/skill-creator/scripts/init.py +0 -0
  444. package/.agent/skills/skill-creator/scripts/package-skill.py +136 -0
  445. package/.agent/skills/skill-creator/scripts/quick-validate.py +103 -0
  446. package/.agent/skills/skill-creator/scripts/run-eval.py +310 -0
  447. package/.agent/skills/skill-creator/scripts/run-loop.py +328 -0
  448. package/.agent/skills/skill-creator/scripts/utils.py +47 -0
  449. package/.agent/skills/skill-stocktake/SKILL.md +193 -0
  450. package/.agent/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
  451. package/.agent/skills/skill-stocktake/scripts/save-results.sh +56 -0
  452. package/.agent/skills/skill-stocktake/scripts/scan.sh +170 -0
  453. package/.agent/skills/social-graph-ranker/SKILL.md +154 -0
  454. package/.agent/skills/springboot-patterns/SKILL.md +314 -0
  455. package/.agent/skills/springboot-security/SKILL.md +272 -0
  456. package/.agent/skills/springboot-tdd/SKILL.md +158 -0
  457. package/.agent/skills/springboot-verification/SKILL.md +231 -0
  458. package/.agent/skills/strategic-compact/SKILL.md +131 -0
  459. package/.agent/skills/strategic-compact/suggest-compact.sh +54 -0
  460. package/.agent/skills/swift-actor-persistence/SKILL.md +143 -0
  461. package/.agent/skills/swift-concurrency-6-2/SKILL.md +216 -0
  462. package/.agent/skills/swift-protocol-di-testing/SKILL.md +190 -0
  463. package/.agent/skills/swiftui-patterns/SKILL.md +259 -0
  464. package/.agent/skills/tdd-workflow/SKILL.md +412 -98
  465. package/.agent/skills/team-builder/SKILL.md +168 -0
  466. package/.agent/skills/token-budget-advisor/SKILL.md +133 -0
  467. package/.agent/skills/ui-demo/SKILL.md +465 -0
  468. package/.agent/skills/ui-ux-pro-max/data/charts.csv +26 -26
  469. package/.agent/skills/ui-ux-pro-max/data/colors.csv +97 -97
  470. package/.agent/skills/ui-ux-pro-max/data/landing.csv +28 -28
  471. package/.agent/skills/ui-ux-pro-max/data/products.csv +96 -96
  472. package/.agent/skills/ui-ux-pro-max/data/stacks/flutter.csv +53 -53
  473. package/.agent/skills/ui-ux-pro-max/data/stacks/html-tailwind.csv +56 -56
  474. package/.agent/skills/ui-ux-pro-max/data/stacks/nextjs.csv +53 -53
  475. package/.agent/skills/ui-ux-pro-max/data/stacks/react-native.csv +52 -52
  476. package/.agent/skills/ui-ux-pro-max/data/stacks/react.csv +54 -54
  477. package/.agent/skills/ui-ux-pro-max/data/stacks/svelte.csv +54 -54
  478. package/.agent/skills/ui-ux-pro-max/data/stacks/swiftui.csv +51 -51
  479. package/.agent/skills/ui-ux-pro-max/data/stacks/vue.csv +50 -50
  480. package/.agent/skills/ui-ux-pro-max/data/styles.csv +68 -68
  481. package/.agent/skills/ui-ux-pro-max/data/ux-guidelines.csv +99 -99
  482. package/.agent/skills/ui-ux-pro-max/scripts/search.py +114 -114
  483. package/.agent/skills/verification-loop/SKILL.md +126 -0
  484. package/.agent/skills/video-editing/SKILL.md +310 -0
  485. package/.agent/skills/videodb/SKILL.md +374 -0
  486. package/.agent/skills/videodb/reference/api-reference.md +550 -0
  487. package/.agent/skills/videodb/reference/capture-reference.md +407 -0
  488. package/.agent/skills/videodb/reference/capture.md +101 -0
  489. package/.agent/skills/videodb/reference/editor.md +443 -0
  490. package/.agent/skills/videodb/reference/generative.md +331 -0
  491. package/.agent/skills/videodb/reference/rtstream-reference.md +564 -0
  492. package/.agent/skills/videodb/reference/rtstream.md +65 -0
  493. package/.agent/skills/videodb/reference/search.md +230 -0
  494. package/.agent/skills/videodb/reference/streaming.md +406 -0
  495. package/.agent/skills/videodb/reference/use-cases.md +118 -0
  496. package/.agent/skills/videodb/scripts/ws-listener.py +282 -0
  497. package/.agent/skills/visa-doc-translate/SKILL.md +117 -0
  498. package/.agent/skills/visa-doc-translate/readme.md +86 -0
  499. package/.agent/skills/workspace-surface-audit/SKILL.md +125 -0
  500. package/.agent/skills/x-api/SKILL.md +230 -0
  501. package/.agent/tasks/two-track-merge-contract.md +29 -0
  502. package/.agent/workflows/aside.md +164 -164
  503. package/.agent/workflows/build-fix.md +62 -62
  504. package/.agent/workflows/checkpoint.md +74 -74
  505. package/.agent/workflows/claw.md +23 -51
  506. package/.agent/workflows/clean-memory.md +34 -0
  507. package/.agent/workflows/code-review.md +289 -40
  508. package/.agent/workflows/context-budget.md +23 -29
  509. package/.agent/workflows/cpp-build.md +173 -173
  510. package/.agent/workflows/cpp-review.md +132 -132
  511. package/.agent/workflows/cpp-test.md +251 -251
  512. package/.agent/workflows/devfleet.md +23 -92
  513. package/.agent/workflows/docs.md +23 -31
  514. package/.agent/workflows/e2e.md +268 -365
  515. package/.agent/workflows/eval.md +23 -120
  516. package/.agent/workflows/evolve.md +178 -178
  517. package/.agent/workflows/flutter-build.md +164 -0
  518. package/.agent/workflows/flutter-review.md +116 -0
  519. package/.agent/workflows/flutter-test.md +144 -0
  520. package/.agent/workflows/gan-build.md +99 -0
  521. package/.agent/workflows/gan-design.md +35 -0
  522. package/.agent/workflows/go-build.md +183 -183
  523. package/.agent/workflows/go-review.md +148 -148
  524. package/.agent/workflows/go-test.md +268 -268
  525. package/.agent/workflows/gradle-build.md +70 -70
  526. package/.agent/workflows/harness-audit.md +73 -71
  527. package/.agent/workflows/instinct-export.md +66 -66
  528. package/.agent/workflows/instinct-import.md +114 -114
  529. package/.agent/workflows/instinct-status.md +59 -59
  530. package/.agent/workflows/jira.md +106 -0
  531. package/.agent/workflows/kotlin-build.md +174 -174
  532. package/.agent/workflows/kotlin-review.md +140 -140
  533. package/.agent/workflows/kotlin-test.md +312 -312
  534. package/.agent/workflows/learn-eval.md +116 -116
  535. package/.agent/workflows/learn.md +70 -70
  536. package/.agent/workflows/loop-start.md +32 -32
  537. package/.agent/workflows/loop-status.md +24 -24
  538. package/.agent/workflows/model-route.md +26 -26
  539. package/.agent/workflows/multi-backend.md +158 -158
  540. package/.agent/workflows/multi-execute.md +315 -315
  541. package/.agent/workflows/multi-frontend.md +158 -158
  542. package/.agent/workflows/multi-plan.md +268 -268
  543. package/.agent/workflows/multi-workflow.md +191 -191
  544. package/.agent/workflows/orchestrate.md +135 -231
  545. package/.agent/workflows/plan.md +117 -115
  546. package/.agent/workflows/pm2.md +272 -272
  547. package/.agent/workflows/projects.md +39 -39
  548. package/.agent/workflows/promote.md +41 -41
  549. package/.agent/workflows/prompt-optimize.md +23 -38
  550. package/.agent/workflows/prp-commit.md +112 -0
  551. package/.agent/workflows/prp-implement.md +385 -0
  552. package/.agent/workflows/prp-plan.md +502 -0
  553. package/.agent/workflows/prp-pr.md +184 -0
  554. package/.agent/workflows/prp-prd.md +447 -0
  555. package/.agent/workflows/prune.md +31 -31
  556. package/.agent/workflows/python-review.md +297 -297
  557. package/.agent/workflows/quality-gate.md +29 -29
  558. package/.agent/workflows/refactor-clean.md +80 -80
  559. package/.agent/workflows/resume-session.md +156 -156
  560. package/.agent/workflows/rules-distill.md +20 -11
  561. package/.agent/workflows/rust-build.md +187 -187
  562. package/.agent/workflows/rust-review.md +142 -142
  563. package/.agent/workflows/rust-test.md +308 -308
  564. package/.agent/workflows/santa-loop.md +175 -0
  565. package/.agent/workflows/save-session.md +275 -275
  566. package/.agent/workflows/sessions.md +333 -333
  567. package/.agent/workflows/setup-pm.md +80 -80
  568. package/.agent/workflows/skill-create.md +174 -174
  569. package/.agent/workflows/skill-health.md +54 -54
  570. package/.agent/workflows/tdd.md +231 -328
  571. package/.agent/workflows/test-coverage.md +69 -69
  572. package/.agent/workflows/update-codemaps.md +72 -72
  573. package/.agent/workflows/update-docs.md +84 -84
  574. package/.agent/workflows/verify.md +23 -59
  575. package/LICENSE +176 -176
  576. package/README.md +28 -20
  577. package/RELEASE.md +32 -36
  578. package/package.json +87 -79
  579. package/scripts/release-check.js +55 -55
  580. package/src/bin/cli.js +399 -53
  581. package/src/lib/installer.js +360 -114
  582. package/src/lib/manifests/stacks.js +122 -0
  583. package/src/lib/slash-commands.js +28 -0
  584. package/src/templates/claude/CLAUDE.en.md +42 -0
  585. package/src/templates/claude/CLAUDE.md +42 -0
  586. package/src/templates/claude/CLAUDE.vi.md +42 -0
  587. package/src/templates/codex/AGENTS.en.md +40 -0
  588. package/src/templates/codex/AGENTS.md +40 -0
  589. package/src/templates/codex/AGENTS.vi.md +40 -0
  590. package/src/templates/cursor/pilo-masterkit.mdc +20 -0
  591. package/src/templates/gemini/GEMINI.en.md +56 -0
  592. package/src/templates/gemini/GEMINI.md +56 -0
  593. package/src/templates/gemini/GEMINI.vi.md +56 -0
  594. 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