@rubix0270/arboris 1.0.2 → 1.0.4

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/package.json +25 -37
  2. package/run.mjs +10 -0
  3. package/dist/cli.mjs +0 -383
  4. package/manifest.json +0 -323
  5. package/prisma/skills/accessibility/SKILL.md +0 -147
  6. package/prisma/skills/agent-architecture-audit/SKILL.md +0 -257
  7. package/prisma/skills/agent-eval/SKILL.md +0 -146
  8. package/prisma/skills/agent-harness-construction/SKILL.md +0 -74
  9. package/prisma/skills/agent-introspection-debugging/SKILL.md +0 -154
  10. package/prisma/skills/agent-payment-x402/SKILL.md +0 -225
  11. package/prisma/skills/agent-self-evaluation/SKILL.md +0 -182
  12. package/prisma/skills/agent-self-evaluation/examples/high-score-example.md +0 -87
  13. package/prisma/skills/agent-self-evaluation/examples/low-score-example.md +0 -86
  14. package/prisma/skills/agent-self-evaluation/references/evaluation-criteria.md +0 -71
  15. package/prisma/skills/agent-self-evaluation/references/hook-integration.md +0 -64
  16. package/prisma/skills/agent-self-evaluation/scripts/evaluate.py +0 -408
  17. package/prisma/skills/agent-self-evaluation/templates/evaluation-report.md +0 -86
  18. package/prisma/skills/agent-sort/SKILL.md +0 -216
  19. package/prisma/skills/agentic-engineering/SKILL.md +0 -64
  20. package/prisma/skills/agentic-os/SKILL.md +0 -388
  21. package/prisma/skills/ai-first-engineering/SKILL.md +0 -52
  22. package/prisma/skills/ai-regression-testing/SKILL.md +0 -386
  23. package/prisma/skills/android-clean-architecture/SKILL.md +0 -340
  24. package/prisma/skills/angular-developer/SKILL.md +0 -155
  25. package/prisma/skills/angular-developer/references/angular-animations.md +0 -160
  26. package/prisma/skills/angular-developer/references/angular-aria.md +0 -410
  27. package/prisma/skills/angular-developer/references/cli.md +0 -86
  28. package/prisma/skills/angular-developer/references/component-harnesses.md +0 -59
  29. package/prisma/skills/angular-developer/references/component-styling.md +0 -91
  30. package/prisma/skills/angular-developer/references/components.md +0 -117
  31. package/prisma/skills/angular-developer/references/creating-services.md +0 -97
  32. package/prisma/skills/angular-developer/references/data-resolvers.md +0 -69
  33. package/prisma/skills/angular-developer/references/define-routes.md +0 -67
  34. package/prisma/skills/angular-developer/references/defining-providers.md +0 -72
  35. package/prisma/skills/angular-developer/references/di-fundamentals.md +0 -120
  36. package/prisma/skills/angular-developer/references/e2e-testing.md +0 -56
  37. package/prisma/skills/angular-developer/references/effects.md +0 -83
  38. package/prisma/skills/angular-developer/references/hierarchical-injectors.md +0 -43
  39. package/prisma/skills/angular-developer/references/host-elements.md +0 -80
  40. package/prisma/skills/angular-developer/references/injection-context.md +0 -63
  41. package/prisma/skills/angular-developer/references/inputs.md +0 -101
  42. package/prisma/skills/angular-developer/references/linked-signal.md +0 -59
  43. package/prisma/skills/angular-developer/references/loading-strategies.md +0 -61
  44. package/prisma/skills/angular-developer/references/mcp.md +0 -108
  45. package/prisma/skills/angular-developer/references/navigate-to-routes.md +0 -69
  46. package/prisma/skills/angular-developer/references/outputs.md +0 -86
  47. package/prisma/skills/angular-developer/references/reactive-forms.md +0 -122
  48. package/prisma/skills/angular-developer/references/rendering-strategies.md +0 -44
  49. package/prisma/skills/angular-developer/references/resource.md +0 -77
  50. package/prisma/skills/angular-developer/references/route-animations.md +0 -56
  51. package/prisma/skills/angular-developer/references/route-guards.md +0 -52
  52. package/prisma/skills/angular-developer/references/router-lifecycle.md +0 -45
  53. package/prisma/skills/angular-developer/references/router-testing.md +0 -87
  54. package/prisma/skills/angular-developer/references/show-routes-with-outlets.md +0 -68
  55. package/prisma/skills/angular-developer/references/signal-forms.md +0 -795
  56. package/prisma/skills/angular-developer/references/signals-overview.md +0 -94
  57. package/prisma/skills/angular-developer/references/tailwind-css.md +0 -69
  58. package/prisma/skills/angular-developer/references/template-driven-forms.md +0 -114
  59. package/prisma/skills/angular-developer/references/testing-fundamentals.md +0 -65
  60. package/prisma/skills/api-connector-builder/SKILL.md +0 -121
  61. package/prisma/skills/api-design/SKILL.md +0 -524
  62. package/prisma/skills/architecture-decision-records/SKILL.md +0 -180
  63. package/prisma/skills/article-writing/SKILL.md +0 -80
  64. package/prisma/skills/automation-audit-ops/SKILL.md +0 -143
  65. package/prisma/skills/autonomous-agent-harness/SKILL.md +0 -274
  66. package/prisma/skills/autonomous-loops/SKILL.md +0 -611
  67. package/prisma/skills/backend-patterns/SKILL.md +0 -562
  68. package/prisma/skills/benchmark/SKILL.md +0 -94
  69. package/prisma/skills/benchmark-methodology/SKILL.md +0 -190
  70. package/prisma/skills/benchmark-optimization-loop/SKILL.md +0 -70
  71. package/prisma/skills/blender-motion-state-inspection/SKILL.md +0 -165
  72. package/prisma/skills/blueprint/SKILL.md +0 -106
  73. package/prisma/skills/brand-discovery/SKILL.md +0 -145
  74. package/prisma/skills/brand-discovery/references/10_purpose-why.md +0 -40
  75. package/prisma/skills/brand-discovery/references/20_positioning.md +0 -44
  76. package/prisma/skills/brand-discovery/references/30_audience-niche.md +0 -52
  77. package/prisma/skills/brand-discovery/references/40_personality-archetype.md +0 -57
  78. package/prisma/skills/brand-discovery/references/50_voice-tone.md +0 -59
  79. package/prisma/skills/brand-discovery/references/60_narrative-story.md +0 -50
  80. package/prisma/skills/brand-discovery/references/70_founder-tension.md +0 -49
  81. package/prisma/skills/brand-discovery/references/90_SYNTHESIS.md +0 -133
  82. package/prisma/skills/brand-voice/SKILL.md +0 -98
  83. package/prisma/skills/brand-voice/references/voice-profile-schema.md +0 -55
  84. package/prisma/skills/browser-qa/SKILL.md +0 -105
  85. package/prisma/skills/bun-runtime/SKILL.md +0 -85
  86. package/prisma/skills/canary-watch/SKILL.md +0 -108
  87. package/prisma/skills/carrier-relationship-management/SKILL.md +0 -212
  88. package/prisma/skills/cisco-ios-patterns/SKILL.md +0 -164
  89. package/prisma/skills/ck/SKILL.md +0 -148
  90. package/prisma/skills/ck/commands/forget.mjs +0 -44
  91. package/prisma/skills/ck/commands/info.mjs +0 -24
  92. package/prisma/skills/ck/commands/init.mjs +0 -143
  93. package/prisma/skills/ck/commands/list.mjs +0 -40
  94. package/prisma/skills/ck/commands/migrate.mjs +0 -202
  95. package/prisma/skills/ck/commands/resume.mjs +0 -36
  96. package/prisma/skills/ck/commands/save.mjs +0 -210
  97. package/prisma/skills/ck/commands/shared.mjs +0 -387
  98. package/prisma/skills/ck/hooks/session-start.mjs +0 -224
  99. package/prisma/skills/claude-devfleet/SKILL.md +0 -112
  100. package/prisma/skills/click-path-audit/SKILL.md +0 -245
  101. package/prisma/skills/clickhouse-io/SKILL.md +0 -440
  102. package/prisma/skills/code-tour/SKILL.md +0 -254
  103. package/prisma/skills/codebase-onboarding/SKILL.md +0 -234
  104. package/prisma/skills/codehealth-mcp/SKILL.md +0 -167
  105. package/prisma/skills/coding-standards/SKILL.md +0 -551
  106. package/prisma/skills/competitive-platform-analysis/SKILL.md +0 -214
  107. package/prisma/skills/competitive-report-structure/SKILL.md +0 -162
  108. package/prisma/skills/compose-multiplatform-patterns/SKILL.md +0 -300
  109. package/prisma/skills/config-gc/SKILL.md +0 -120
  110. package/prisma/skills/configure-ecc/SKILL.md +0 -385
  111. package/prisma/skills/connections-optimizer/SKILL.md +0 -190
  112. package/prisma/skills/content-engine/SKILL.md +0 -132
  113. package/prisma/skills/content-hash-cache-pattern/SKILL.md +0 -162
  114. package/prisma/skills/context-budget/SKILL.md +0 -136
  115. package/prisma/skills/continuous-agent-loop/SKILL.md +0 -46
  116. package/prisma/skills/continuous-learning/SKILL.md +0 -132
  117. package/prisma/skills/continuous-learning/config.json +0 -18
  118. package/prisma/skills/continuous-learning/evaluate-session.sh +0 -69
  119. package/prisma/skills/continuous-learning-v2/SKILL.md +0 -361
  120. package/prisma/skills/continuous-learning-v2/agents/observer-loop.sh +0 -359
  121. package/prisma/skills/continuous-learning-v2/agents/observer.md +0 -189
  122. package/prisma/skills/continuous-learning-v2/agents/session-guardian.sh +0 -150
  123. package/prisma/skills/continuous-learning-v2/agents/start-observer.sh +0 -248
  124. package/prisma/skills/continuous-learning-v2/config.json +0 -8
  125. package/prisma/skills/continuous-learning-v2/hooks/observe.sh +0 -585
  126. package/prisma/skills/continuous-learning-v2/scripts/detect-project.sh +0 -322
  127. package/prisma/skills/continuous-learning-v2/scripts/instinct-cli.py +0 -1956
  128. package/prisma/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +0 -31
  129. package/prisma/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +0 -68
  130. package/prisma/skills/continuous-learning-v2/scripts/test_parse_instinct.py +0 -1421
  131. package/prisma/skills/cost-aware-llm-pipeline/SKILL.md +0 -184
  132. package/prisma/skills/cost-tracking/SKILL.md +0 -97
  133. package/prisma/skills/council/SKILL.md +0 -204
  134. package/prisma/skills/cpp-coding-standards/SKILL.md +0 -724
  135. package/prisma/skills/cpp-testing/SKILL.md +0 -325
  136. package/prisma/skills/crosspost/SKILL.md +0 -112
  137. package/prisma/skills/csharp-testing/SKILL.md +0 -322
  138. package/prisma/skills/customer-billing-ops/SKILL.md +0 -141
  139. package/prisma/skills/customs-trade-compliance/SKILL.md +0 -263
  140. package/prisma/skills/dart-flutter-patterns/SKILL.md +0 -564
  141. package/prisma/skills/dashboard-builder/SKILL.md +0 -109
  142. package/prisma/skills/data-scraper-agent/SKILL.md +0 -765
  143. package/prisma/skills/data-throughput-accelerator/SKILL.md +0 -73
  144. package/prisma/skills/database-migrations/SKILL.md +0 -430
  145. package/prisma/skills/deep-research/SKILL.md +0 -160
  146. package/prisma/skills/defi-amm-security/SKILL.md +0 -167
  147. package/prisma/skills/delivery-gate/SKILL.md +0 -126
  148. package/prisma/skills/delivery-gate/hooks/quality-gate.py +0 -220
  149. package/prisma/skills/deployment-patterns/SKILL.md +0 -428
  150. package/prisma/skills/design-system/SKILL.md +0 -83
  151. package/prisma/skills/django-celery/SKILL.md +0 -458
  152. package/prisma/skills/django-patterns/SKILL.md +0 -735
  153. package/prisma/skills/django-security/SKILL.md +0 -644
  154. package/prisma/skills/django-tdd/SKILL.md +0 -730
  155. package/prisma/skills/django-verification/SKILL.md +0 -470
  156. package/prisma/skills/dmux-workflows/SKILL.md +0 -192
  157. package/prisma/skills/docker-patterns/SKILL.md +0 -365
  158. package/prisma/skills/documentation-lookup/SKILL.md +0 -91
  159. package/prisma/skills/dotnet-patterns/SKILL.md +0 -322
  160. package/prisma/skills/dynamic-workflow-mode/SKILL.md +0 -124
  161. package/prisma/skills/e2e-testing/SKILL.md +0 -327
  162. package/prisma/skills/ecc-guide/SKILL.md +0 -190
  163. package/prisma/skills/ecc-recipes/SKILL.md +0 -149
  164. package/prisma/skills/ecc-tools-cost-audit/SKILL.md +0 -161
  165. package/prisma/skills/email-ops/SKILL.md +0 -122
  166. package/prisma/skills/energy-procurement/SKILL.md +0 -228
  167. package/prisma/skills/enterprise-agent-ops/SKILL.md +0 -51
  168. package/prisma/skills/error-handling/SKILL.md +0 -377
  169. package/prisma/skills/eval-harness/SKILL.md +0 -271
  170. package/prisma/skills/evm-token-decimals/SKILL.md +0 -131
  171. package/prisma/skills/exa-search/SKILL.md +0 -108
  172. package/prisma/skills/fal-ai-media/SKILL.md +0 -289
  173. package/prisma/skills/fastapi-patterns/SKILL.md +0 -514
  174. package/prisma/skills/finance-billing-ops/SKILL.md +0 -128
  175. package/prisma/skills/flox-environments/SKILL.md +0 -497
  176. package/prisma/skills/flutter-dart-code-review/SKILL.md +0 -436
  177. package/prisma/skills/foundation-models-on-device/SKILL.md +0 -243
  178. package/prisma/skills/frontend-a11y/SKILL.md +0 -446
  179. package/prisma/skills/frontend-design-direction/SKILL.md +0 -93
  180. package/prisma/skills/frontend-patterns/SKILL.md +0 -657
  181. package/prisma/skills/frontend-slides/SKILL.md +0 -185
  182. package/prisma/skills/frontend-slides/STYLE_PRESETS.md +0 -330
  183. package/prisma/skills/frontend-slides/animation-patterns.md +0 -122
  184. package/prisma/skills/frontend-slides/html-template.md +0 -419
  185. package/prisma/skills/frontend-slides/scripts/export-pdf.sh +0 -418
  186. package/prisma/skills/frontend-slides/scripts/extract-pptx.py +0 -96
  187. package/prisma/skills/frontend-slides/viewport-base.css +0 -153
  188. package/prisma/skills/fsharp-testing/SKILL.md +0 -281
  189. package/prisma/skills/gan-style-harness/SKILL.md +0 -279
  190. package/prisma/skills/gateguard/SKILL.md +0 -133
  191. package/prisma/skills/generating-python-installer/SKILL.md +0 -820
  192. package/prisma/skills/git-workflow/SKILL.md +0 -716
  193. package/prisma/skills/github-ops/SKILL.md +0 -145
  194. package/prisma/skills/golang-patterns/SKILL.md +0 -675
  195. package/prisma/skills/golang-testing/SKILL.md +0 -721
  196. package/prisma/skills/google-workspace-ops/SKILL.md +0 -96
  197. package/prisma/skills/growth-log/SKILL.md +0 -128
  198. package/prisma/skills/healthcare-cdss-patterns/SKILL.md +0 -246
  199. package/prisma/skills/healthcare-emr-patterns/SKILL.md +0 -160
  200. package/prisma/skills/healthcare-eval-harness/SKILL.md +0 -208
  201. package/prisma/skills/healthcare-phi-compliance/SKILL.md +0 -146
  202. package/prisma/skills/hermes-imports/SKILL.md +0 -89
  203. package/prisma/skills/hexagonal-architecture/SKILL.md +0 -277
  204. package/prisma/skills/hipaa-compliance/SKILL.md +0 -79
  205. package/prisma/skills/homelab-network-readiness/SKILL.md +0 -170
  206. package/prisma/skills/homelab-network-setup/SKILL.md +0 -130
  207. package/prisma/skills/homelab-pihole-dns/SKILL.md +0 -275
  208. package/prisma/skills/homelab-vlan-segmentation/SKILL.md +0 -312
  209. package/prisma/skills/homelab-wireguard-vpn/SKILL.md +0 -306
  210. package/prisma/skills/hookify-rules/SKILL.md +0 -128
  211. package/prisma/skills/inherit-legacy-style/SKILL.md +0 -157
  212. package/prisma/skills/intent-driven-development/SKILL.md +0 -360
  213. package/prisma/skills/inventory-demand-planning/SKILL.md +0 -247
  214. package/prisma/skills/investor-materials/SKILL.md +0 -97
  215. package/prisma/skills/investor-outreach/SKILL.md +0 -92
  216. package/prisma/skills/ios-icon-gen/SKILL.md +0 -158
  217. package/prisma/skills/ios-icon-gen/scripts/generate_icons.swift +0 -258
  218. package/prisma/skills/ios-icon-gen/scripts/iconify_gen.sh +0 -235
  219. package/prisma/skills/iterative-retrieval/SKILL.md +0 -212
  220. package/prisma/skills/ito-basket-compare/SKILL.md +0 -64
  221. package/prisma/skills/ito-data-atlas-agent/SKILL.md +0 -64
  222. package/prisma/skills/ito-market-intelligence/SKILL.md +0 -61
  223. package/prisma/skills/ito-trade-planner/SKILL.md +0 -68
  224. package/prisma/skills/java-coding-standards/SKILL.md +0 -384
  225. package/prisma/skills/jira-integration/SKILL.md +0 -303
  226. package/prisma/skills/jpa-patterns/SKILL.md +0 -152
  227. package/prisma/skills/knowledge-ops/SKILL.md +0 -155
  228. package/prisma/skills/kotlin-coroutines-flows/SKILL.md +0 -285
  229. package/prisma/skills/kotlin-exposed-patterns/SKILL.md +0 -720
  230. package/prisma/skills/kotlin-ktor-patterns/SKILL.md +0 -690
  231. package/prisma/skills/kotlin-patterns/SKILL.md +0 -712
  232. package/prisma/skills/kotlin-testing/SKILL.md +0 -825
  233. package/prisma/skills/kubernetes-patterns/SKILL.md +0 -756
  234. package/prisma/skills/laravel-patterns/SKILL.md +0 -416
  235. package/prisma/skills/laravel-plugin-discovery/SKILL.md +0 -230
  236. package/prisma/skills/laravel-security/SKILL.md +0 -948
  237. package/prisma/skills/laravel-tdd/SKILL.md +0 -675
  238. package/prisma/skills/laravel-verification/SKILL.md +0 -180
  239. package/prisma/skills/latency-critical-systems/SKILL.md +0 -74
  240. package/prisma/skills/lead-intelligence/SKILL.md +0 -322
  241. package/prisma/skills/lead-intelligence/agents/enrichment-agent.md +0 -85
  242. package/prisma/skills/lead-intelligence/agents/mutual-mapper.md +0 -75
  243. package/prisma/skills/lead-intelligence/agents/outreach-drafter.md +0 -98
  244. package/prisma/skills/lead-intelligence/agents/signal-scorer.md +0 -60
  245. package/prisma/skills/liquid-glass-design/SKILL.md +0 -279
  246. package/prisma/skills/llm-trading-agent-security/SKILL.md +0 -147
  247. package/prisma/skills/logistics-exception-management/SKILL.md +0 -222
  248. package/prisma/skills/loop-design-check/SKILL.md +0 -143
  249. package/prisma/skills/mailtrap-email-integration/SKILL.md +0 -77
  250. package/prisma/skills/make-interfaces-feel-better/SKILL.md +0 -152
  251. package/prisma/skills/manim-video/SKILL.md +0 -90
  252. package/prisma/skills/manim-video/assets/network_graph_scene.py +0 -52
  253. package/prisma/skills/market-research/SKILL.md +0 -76
  254. package/prisma/skills/marketing-campaign/SKILL.md +0 -114
  255. package/prisma/skills/mcp-server-patterns/SKILL.md +0 -70
  256. package/prisma/skills/messages-ops/SKILL.md +0 -105
  257. package/prisma/skills/ml-adoption-playbook/SKILL.md +0 -57
  258. package/prisma/skills/mle-workflow/SKILL.md +0 -347
  259. package/prisma/skills/motion-advanced/SKILL.md +0 -596
  260. package/prisma/skills/motion-foundations/SKILL.md +0 -299
  261. package/prisma/skills/motion-patterns/SKILL.md +0 -434
  262. package/prisma/skills/motion-ui/SKILL.md +0 -576
  263. package/prisma/skills/mysql-patterns/SKILL.md +0 -413
  264. package/prisma/skills/nanoclaw-repl/SKILL.md +0 -34
  265. package/prisma/skills/nestjs-patterns/SKILL.md +0 -231
  266. package/prisma/skills/netmiko-ssh-automation/SKILL.md +0 -174
  267. package/prisma/skills/network-bgp-diagnostics/SKILL.md +0 -168
  268. package/prisma/skills/network-config-validation/SKILL.md +0 -211
  269. package/prisma/skills/network-interface-health/SKILL.md +0 -153
  270. package/prisma/skills/nextjs-turbopack/SKILL.md +0 -58
  271. package/prisma/skills/nodejs-keccak256/SKILL.md +0 -103
  272. package/prisma/skills/nutrient-document-processing/SKILL.md +0 -168
  273. package/prisma/skills/nuxt4-patterns/SKILL.md +0 -101
  274. package/prisma/skills/openclaw-persona-forge/SKILL.md +0 -289
  275. package/prisma/skills/openclaw-persona-forge/gacha.py +0 -224
  276. package/prisma/skills/openclaw-persona-forge/gacha.sh +0 -5
  277. package/prisma/skills/openclaw-persona-forge/references/avatar-style.md +0 -124
  278. package/prisma/skills/openclaw-persona-forge/references/boundary-rules.md +0 -53
  279. package/prisma/skills/openclaw-persona-forge/references/error-handling.md +0 -53
  280. package/prisma/skills/openclaw-persona-forge/references/identity-tension.md +0 -48
  281. package/prisma/skills/openclaw-persona-forge/references/naming-system.md +0 -39
  282. package/prisma/skills/openclaw-persona-forge/references/output-template.md +0 -166
  283. package/prisma/skills/opensource-pipeline/SKILL.md +0 -256
  284. package/prisma/skills/orch-add-feature/SKILL.md +0 -45
  285. package/prisma/skills/orch-build-mvp/SKILL.md +0 -49
  286. package/prisma/skills/orch-change-feature/SKILL.md +0 -43
  287. package/prisma/skills/orch-fix-defect/SKILL.md +0 -43
  288. package/prisma/skills/orch-pipeline/SKILL.md +0 -121
  289. package/prisma/skills/orch-refine-code/SKILL.md +0 -44
  290. package/prisma/skills/parallel-execution-optimizer/SKILL.md +0 -73
  291. package/prisma/skills/perl-patterns/SKILL.md +0 -505
  292. package/prisma/skills/perl-security/SKILL.md +0 -504
  293. package/prisma/skills/perl-testing/SKILL.md +0 -476
  294. package/prisma/skills/plan-orchestrate/SKILL.md +0 -263
  295. package/prisma/skills/plankton-code-quality/SKILL.md +0 -237
  296. package/prisma/skills/postgres-patterns/SKILL.md +0 -148
  297. package/prisma/skills/prediction-market-oracle-research/SKILL.md +0 -64
  298. package/prisma/skills/prediction-market-risk-review/SKILL.md +0 -61
  299. package/prisma/skills/prisma-patterns/SKILL.md +0 -401
  300. package/prisma/skills/product-capability/SKILL.md +0 -142
  301. package/prisma/skills/product-lens/SKILL.md +0 -93
  302. package/prisma/skills/production-audit/SKILL.md +0 -207
  303. package/prisma/skills/production-scheduling/SKILL.md +0 -238
  304. package/prisma/skills/project-flow-ops/SKILL.md +0 -112
  305. package/prisma/skills/prompt-optimizer/SKILL.md +0 -398
  306. package/prisma/skills/python-patterns/SKILL.md +0 -751
  307. package/prisma/skills/python-testing/SKILL.md +0 -817
  308. package/prisma/skills/pytorch-patterns/SKILL.md +0 -397
  309. package/prisma/skills/quality-nonconformance/SKILL.md +0 -260
  310. package/prisma/skills/quarkus-patterns/SKILL.md +0 -723
  311. package/prisma/skills/quarkus-security/SKILL.md +0 -468
  312. package/prisma/skills/quarkus-tdd/SKILL.md +0 -812
  313. package/prisma/skills/quarkus-verification/SKILL.md +0 -480
  314. package/prisma/skills/ralphinho-rfc-pipeline/SKILL.md +0 -68
  315. package/prisma/skills/react-native-patterns/SKILL.md +0 -326
  316. package/prisma/skills/react-patterns/SKILL.md +0 -342
  317. package/prisma/skills/react-performance/SKILL.md +0 -575
  318. package/prisma/skills/react-testing/SKILL.md +0 -424
  319. package/prisma/skills/recsys-pipeline-architect/SKILL.md +0 -115
  320. package/prisma/skills/recursive-decision-ledger/SKILL.md +0 -80
  321. package/prisma/skills/redis-patterns/SKILL.md +0 -404
  322. package/prisma/skills/regex-vs-llm-structured-text/SKILL.md +0 -221
  323. package/prisma/skills/remotion-video-creation/SKILL.md +0 -43
  324. package/prisma/skills/remotion-video-creation/rules/3d.md +0 -86
  325. package/prisma/skills/remotion-video-creation/rules/animations.md +0 -29
  326. package/prisma/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +0 -173
  327. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +0 -100
  328. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +0 -108
  329. package/prisma/skills/remotion-video-creation/rules/assets.md +0 -78
  330. package/prisma/skills/remotion-video-creation/rules/audio.md +0 -172
  331. package/prisma/skills/remotion-video-creation/rules/calculate-metadata.md +0 -104
  332. package/prisma/skills/remotion-video-creation/rules/can-decode.md +0 -75
  333. package/prisma/skills/remotion-video-creation/rules/charts.md +0 -58
  334. package/prisma/skills/remotion-video-creation/rules/compositions.md +0 -146
  335. package/prisma/skills/remotion-video-creation/rules/display-captions.md +0 -126
  336. package/prisma/skills/remotion-video-creation/rules/extract-frames.md +0 -229
  337. package/prisma/skills/remotion-video-creation/rules/fonts.md +0 -152
  338. package/prisma/skills/remotion-video-creation/rules/get-audio-duration.md +0 -58
  339. package/prisma/skills/remotion-video-creation/rules/get-video-dimensions.md +0 -68
  340. package/prisma/skills/remotion-video-creation/rules/get-video-duration.md +0 -58
  341. package/prisma/skills/remotion-video-creation/rules/gifs.md +0 -138
  342. package/prisma/skills/remotion-video-creation/rules/images.md +0 -130
  343. package/prisma/skills/remotion-video-creation/rules/import-srt-captions.md +0 -67
  344. package/prisma/skills/remotion-video-creation/rules/lottie.md +0 -67
  345. package/prisma/skills/remotion-video-creation/rules/measuring-dom-nodes.md +0 -34
  346. package/prisma/skills/remotion-video-creation/rules/measuring-text.md +0 -143
  347. package/prisma/skills/remotion-video-creation/rules/sequencing.md +0 -106
  348. package/prisma/skills/remotion-video-creation/rules/tailwind.md +0 -11
  349. package/prisma/skills/remotion-video-creation/rules/text-animations.md +0 -20
  350. package/prisma/skills/remotion-video-creation/rules/timing.md +0 -179
  351. package/prisma/skills/remotion-video-creation/rules/transcribe-captions.md +0 -19
  352. package/prisma/skills/remotion-video-creation/rules/transitions.md +0 -122
  353. package/prisma/skills/remotion-video-creation/rules/trimming.md +0 -52
  354. package/prisma/skills/remotion-video-creation/rules/videos.md +0 -171
  355. package/prisma/skills/repo-scan/SKILL.md +0 -79
  356. package/prisma/skills/research-ops/SKILL.md +0 -113
  357. package/prisma/skills/returns-reverse-logistics/SKILL.md +0 -240
  358. package/prisma/skills/rules-distill/SKILL.md +0 -265
  359. package/prisma/skills/rules-distill/scripts/scan-rules.sh +0 -58
  360. package/prisma/skills/rules-distill/scripts/scan-skills.sh +0 -129
  361. package/prisma/skills/rust-patterns/SKILL.md +0 -500
  362. package/prisma/skills/rust-testing/SKILL.md +0 -501
  363. package/prisma/skills/safety-guard/SKILL.md +0 -76
  364. package/prisma/skills/santa-method/SKILL.md +0 -307
  365. package/prisma/skills/scientific-db-pubmed-database/SKILL.md +0 -176
  366. package/prisma/skills/scientific-db-uspto-database/SKILL.md +0 -178
  367. package/prisma/skills/scientific-pkg-gget/SKILL.md +0 -167
  368. package/prisma/skills/scientific-thinking-literature-review/SKILL.md +0 -193
  369. package/prisma/skills/scientific-thinking-scholar-evaluation/SKILL.md +0 -161
  370. package/prisma/skills/search-first/SKILL.md +0 -183
  371. package/prisma/skills/security-bounty-hunter/SKILL.md +0 -100
  372. package/prisma/skills/security-review/SKILL.md +0 -504
  373. package/prisma/skills/security-review/cloud-infrastructure-security.md +0 -361
  374. package/prisma/skills/security-scan/SKILL.md +0 -166
  375. package/prisma/skills/seo/SKILL.md +0 -155
  376. package/prisma/skills/skill-comply/SKILL.md +0 -59
  377. package/prisma/skills/skill-comply/fixtures/compliant_trace.jsonl +0 -5
  378. package/prisma/skills/skill-comply/fixtures/noncompliant_trace.jsonl +0 -3
  379. package/prisma/skills/skill-comply/fixtures/tdd_spec.yaml +0 -44
  380. package/prisma/skills/skill-comply/prompts/classifier.md +0 -24
  381. package/prisma/skills/skill-comply/prompts/scenario_generator.md +0 -62
  382. package/prisma/skills/skill-comply/prompts/spec_generator.md +0 -42
  383. package/prisma/skills/skill-comply/pyproject.toml +0 -15
  384. package/prisma/skills/skill-comply/scripts/__init__.py +0 -0
  385. package/prisma/skills/skill-comply/scripts/classifier.py +0 -85
  386. package/prisma/skills/skill-comply/scripts/grader.py +0 -124
  387. package/prisma/skills/skill-comply/scripts/parser.py +0 -107
  388. package/prisma/skills/skill-comply/scripts/report.py +0 -170
  389. package/prisma/skills/skill-comply/scripts/run.py +0 -127
  390. package/prisma/skills/skill-comply/scripts/runner.py +0 -194
  391. package/prisma/skills/skill-comply/scripts/scenario_generator.py +0 -70
  392. package/prisma/skills/skill-comply/scripts/spec_generator.py +0 -72
  393. package/prisma/skills/skill-comply/scripts/utils.py +0 -13
  394. package/prisma/skills/skill-comply/tests/test_grader.py +0 -197
  395. package/prisma/skills/skill-comply/tests/test_parser.py +0 -90
  396. package/prisma/skills/skill-comply/tests/test_runner.py +0 -172
  397. package/prisma/skills/skill-scout/SKILL.md +0 -141
  398. package/prisma/skills/skill-stocktake/SKILL.md +0 -195
  399. package/prisma/skills/skill-stocktake/scripts/quick-diff.sh +0 -87
  400. package/prisma/skills/skill-stocktake/scripts/save-results.sh +0 -56
  401. package/prisma/skills/skill-stocktake/scripts/scan.sh +0 -170
  402. package/prisma/skills/social-graph-ranker/SKILL.md +0 -155
  403. package/prisma/skills/social-publisher/SKILL.md +0 -130
  404. package/prisma/skills/springboot-patterns/SKILL.md +0 -315
  405. package/prisma/skills/springboot-security/SKILL.md +0 -273
  406. package/prisma/skills/springboot-tdd/SKILL.md +0 -159
  407. package/prisma/skills/springboot-verification/SKILL.md +0 -232
  408. package/prisma/skills/strategic-compact/SKILL.md +0 -136
  409. package/prisma/skills/swift-actor-persistence/SKILL.md +0 -144
  410. package/prisma/skills/swift-concurrency-6-2/SKILL.md +0 -216
  411. package/prisma/skills/swift-protocol-di-testing/SKILL.md +0 -191
  412. package/prisma/skills/swiftui-patterns/SKILL.md +0 -259
  413. package/prisma/skills/taste/SKILL.md +0 -264
  414. package/prisma/skills/taste/references/genre-taxonomy.md +0 -87
  415. package/prisma/skills/tdd-workflow/SKILL.md +0 -583
  416. package/prisma/skills/team-agent-orchestration/SKILL.md +0 -111
  417. package/prisma/skills/team-builder/SKILL.md +0 -169
  418. package/prisma/skills/terminal-ops/SKILL.md +0 -110
  419. package/prisma/skills/tinystruct-patterns/SKILL.md +0 -279
  420. package/prisma/skills/tinystruct-patterns/references/architecture.md +0 -90
  421. package/prisma/skills/tinystruct-patterns/references/data-handling.md +0 -60
  422. package/prisma/skills/tinystruct-patterns/references/database.md +0 -99
  423. package/prisma/skills/tinystruct-patterns/references/routing.md +0 -64
  424. package/prisma/skills/tinystruct-patterns/references/system-usage.md +0 -97
  425. package/prisma/skills/tinystruct-patterns/references/testing.md +0 -72
  426. package/prisma/skills/token-budget-advisor/SKILL.md +0 -134
  427. package/prisma/skills/ui-demo/SKILL.md +0 -466
  428. package/prisma/skills/ui-to-vue/SKILL.md +0 -135
  429. package/prisma/skills/uncloud/SKILL.md +0 -344
  430. package/prisma/skills/unified-notifications-ops/SKILL.md +0 -188
  431. package/prisma/skills/verification-loop/SKILL.md +0 -127
  432. package/prisma/skills/video-editing/SKILL.md +0 -311
  433. package/prisma/skills/videodb/SKILL.md +0 -375
  434. package/prisma/skills/videodb/reference/api-reference.md +0 -550
  435. package/prisma/skills/videodb/reference/capture-reference.md +0 -407
  436. package/prisma/skills/videodb/reference/capture.md +0 -101
  437. package/prisma/skills/videodb/reference/editor.md +0 -443
  438. package/prisma/skills/videodb/reference/generative.md +0 -331
  439. package/prisma/skills/videodb/reference/rtstream-reference.md +0 -564
  440. package/prisma/skills/videodb/reference/rtstream.md +0 -65
  441. package/prisma/skills/videodb/reference/search.md +0 -230
  442. package/prisma/skills/videodb/reference/streaming.md +0 -406
  443. package/prisma/skills/videodb/reference/use-cases.md +0 -118
  444. package/prisma/skills/videodb/scripts/ws_listener.py +0 -282
  445. package/prisma/skills/visa-doc-translate/README.md +0 -86
  446. package/prisma/skills/visa-doc-translate/SKILL.md +0 -117
  447. package/prisma/skills/vite-patterns/SKILL.md +0 -450
  448. package/prisma/skills/vue-patterns/SKILL.md +0 -471
  449. package/prisma/skills/windows-desktop-e2e/SKILL.md +0 -888
  450. package/prisma/skills/workspace-surface-audit/SKILL.md +0 -126
  451. package/prisma/skills/x-api/SKILL.md +0 -235
@@ -1,524 +0,0 @@
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)
@@ -1,180 +0,0 @@
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