@rubix0270/arboris 1.0.0

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