@heytherevibin/skillforge 0.2.1

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