arboris-cli 1.0.0 → 1.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (451) hide show
  1. package/dist/cli.mjs +420 -0
  2. package/manifest.json +602 -0
  3. package/package.json +22 -10
  4. package/prisma/skills/accessibility/SKILL.md +147 -0
  5. package/prisma/skills/agent-architecture-audit/SKILL.md +257 -0
  6. package/prisma/skills/agent-eval/SKILL.md +146 -0
  7. package/prisma/skills/agent-harness-construction/SKILL.md +74 -0
  8. package/prisma/skills/agent-introspection-debugging/SKILL.md +154 -0
  9. package/prisma/skills/agent-payment-x402/SKILL.md +225 -0
  10. package/prisma/skills/agent-self-evaluation/SKILL.md +182 -0
  11. package/prisma/skills/agent-self-evaluation/examples/high-score-example.md +87 -0
  12. package/prisma/skills/agent-self-evaluation/examples/low-score-example.md +86 -0
  13. package/prisma/skills/agent-self-evaluation/references/evaluation-criteria.md +71 -0
  14. package/prisma/skills/agent-self-evaluation/references/hook-integration.md +64 -0
  15. package/prisma/skills/agent-self-evaluation/scripts/evaluate.py +408 -0
  16. package/prisma/skills/agent-self-evaluation/templates/evaluation-report.md +86 -0
  17. package/prisma/skills/agent-sort/SKILL.md +216 -0
  18. package/prisma/skills/agentic-engineering/SKILL.md +64 -0
  19. package/prisma/skills/agentic-os/SKILL.md +388 -0
  20. package/prisma/skills/ai-first-engineering/SKILL.md +52 -0
  21. package/prisma/skills/ai-regression-testing/SKILL.md +386 -0
  22. package/prisma/skills/android-clean-architecture/SKILL.md +340 -0
  23. package/prisma/skills/angular-developer/SKILL.md +155 -0
  24. package/prisma/skills/angular-developer/references/angular-animations.md +160 -0
  25. package/prisma/skills/angular-developer/references/angular-aria.md +410 -0
  26. package/prisma/skills/angular-developer/references/cli.md +86 -0
  27. package/prisma/skills/angular-developer/references/component-harnesses.md +59 -0
  28. package/prisma/skills/angular-developer/references/component-styling.md +91 -0
  29. package/prisma/skills/angular-developer/references/components.md +117 -0
  30. package/prisma/skills/angular-developer/references/creating-services.md +97 -0
  31. package/prisma/skills/angular-developer/references/data-resolvers.md +69 -0
  32. package/prisma/skills/angular-developer/references/define-routes.md +67 -0
  33. package/prisma/skills/angular-developer/references/defining-providers.md +72 -0
  34. package/prisma/skills/angular-developer/references/di-fundamentals.md +120 -0
  35. package/prisma/skills/angular-developer/references/e2e-testing.md +56 -0
  36. package/prisma/skills/angular-developer/references/effects.md +83 -0
  37. package/prisma/skills/angular-developer/references/hierarchical-injectors.md +43 -0
  38. package/prisma/skills/angular-developer/references/host-elements.md +80 -0
  39. package/prisma/skills/angular-developer/references/injection-context.md +63 -0
  40. package/prisma/skills/angular-developer/references/inputs.md +101 -0
  41. package/prisma/skills/angular-developer/references/linked-signal.md +59 -0
  42. package/prisma/skills/angular-developer/references/loading-strategies.md +61 -0
  43. package/prisma/skills/angular-developer/references/mcp.md +108 -0
  44. package/prisma/skills/angular-developer/references/navigate-to-routes.md +69 -0
  45. package/prisma/skills/angular-developer/references/outputs.md +86 -0
  46. package/prisma/skills/angular-developer/references/reactive-forms.md +122 -0
  47. package/prisma/skills/angular-developer/references/rendering-strategies.md +44 -0
  48. package/prisma/skills/angular-developer/references/resource.md +77 -0
  49. package/prisma/skills/angular-developer/references/route-animations.md +56 -0
  50. package/prisma/skills/angular-developer/references/route-guards.md +52 -0
  51. package/prisma/skills/angular-developer/references/router-lifecycle.md +45 -0
  52. package/prisma/skills/angular-developer/references/router-testing.md +87 -0
  53. package/prisma/skills/angular-developer/references/show-routes-with-outlets.md +68 -0
  54. package/prisma/skills/angular-developer/references/signal-forms.md +795 -0
  55. package/prisma/skills/angular-developer/references/signals-overview.md +94 -0
  56. package/prisma/skills/angular-developer/references/tailwind-css.md +69 -0
  57. package/prisma/skills/angular-developer/references/template-driven-forms.md +114 -0
  58. package/prisma/skills/angular-developer/references/testing-fundamentals.md +65 -0
  59. package/prisma/skills/api-connector-builder/SKILL.md +121 -0
  60. package/prisma/skills/api-design/SKILL.md +524 -0
  61. package/prisma/skills/architecture-decision-records/SKILL.md +180 -0
  62. package/prisma/skills/article-writing/SKILL.md +80 -0
  63. package/prisma/skills/automation-audit-ops/SKILL.md +143 -0
  64. package/prisma/skills/autonomous-agent-harness/SKILL.md +274 -0
  65. package/prisma/skills/autonomous-loops/SKILL.md +611 -0
  66. package/prisma/skills/backend-patterns/SKILL.md +562 -0
  67. package/prisma/skills/benchmark/SKILL.md +94 -0
  68. package/prisma/skills/benchmark-methodology/SKILL.md +190 -0
  69. package/prisma/skills/benchmark-optimization-loop/SKILL.md +70 -0
  70. package/prisma/skills/blender-motion-state-inspection/SKILL.md +165 -0
  71. package/prisma/skills/blueprint/SKILL.md +106 -0
  72. package/prisma/skills/brand-discovery/SKILL.md +145 -0
  73. package/prisma/skills/brand-discovery/references/10_purpose-why.md +40 -0
  74. package/prisma/skills/brand-discovery/references/20_positioning.md +44 -0
  75. package/prisma/skills/brand-discovery/references/30_audience-niche.md +52 -0
  76. package/prisma/skills/brand-discovery/references/40_personality-archetype.md +57 -0
  77. package/prisma/skills/brand-discovery/references/50_voice-tone.md +59 -0
  78. package/prisma/skills/brand-discovery/references/60_narrative-story.md +50 -0
  79. package/prisma/skills/brand-discovery/references/70_founder-tension.md +49 -0
  80. package/prisma/skills/brand-discovery/references/90_SYNTHESIS.md +133 -0
  81. package/prisma/skills/brand-voice/SKILL.md +98 -0
  82. package/prisma/skills/brand-voice/references/voice-profile-schema.md +55 -0
  83. package/prisma/skills/browser-qa/SKILL.md +105 -0
  84. package/prisma/skills/bun-runtime/SKILL.md +85 -0
  85. package/prisma/skills/canary-watch/SKILL.md +108 -0
  86. package/prisma/skills/carrier-relationship-management/SKILL.md +212 -0
  87. package/prisma/skills/cisco-ios-patterns/SKILL.md +164 -0
  88. package/prisma/skills/ck/SKILL.md +148 -0
  89. package/prisma/skills/ck/commands/forget.mjs +44 -0
  90. package/prisma/skills/ck/commands/info.mjs +24 -0
  91. package/prisma/skills/ck/commands/init.mjs +143 -0
  92. package/prisma/skills/ck/commands/list.mjs +40 -0
  93. package/prisma/skills/ck/commands/migrate.mjs +202 -0
  94. package/prisma/skills/ck/commands/resume.mjs +36 -0
  95. package/prisma/skills/ck/commands/save.mjs +210 -0
  96. package/prisma/skills/ck/commands/shared.mjs +387 -0
  97. package/prisma/skills/ck/hooks/session-start.mjs +224 -0
  98. package/prisma/skills/claude-devfleet/SKILL.md +112 -0
  99. package/prisma/skills/click-path-audit/SKILL.md +245 -0
  100. package/prisma/skills/clickhouse-io/SKILL.md +440 -0
  101. package/prisma/skills/code-tour/SKILL.md +254 -0
  102. package/prisma/skills/codebase-onboarding/SKILL.md +234 -0
  103. package/prisma/skills/codehealth-mcp/SKILL.md +167 -0
  104. package/prisma/skills/coding-standards/SKILL.md +551 -0
  105. package/prisma/skills/competitive-platform-analysis/SKILL.md +214 -0
  106. package/prisma/skills/competitive-report-structure/SKILL.md +162 -0
  107. package/prisma/skills/compose-multiplatform-patterns/SKILL.md +300 -0
  108. package/prisma/skills/config-gc/SKILL.md +120 -0
  109. package/prisma/skills/configure-ecc/SKILL.md +385 -0
  110. package/prisma/skills/connections-optimizer/SKILL.md +190 -0
  111. package/prisma/skills/content-engine/SKILL.md +132 -0
  112. package/prisma/skills/content-hash-cache-pattern/SKILL.md +162 -0
  113. package/prisma/skills/context-budget/SKILL.md +136 -0
  114. package/prisma/skills/continuous-agent-loop/SKILL.md +46 -0
  115. package/prisma/skills/continuous-learning/SKILL.md +132 -0
  116. package/prisma/skills/continuous-learning/config.json +18 -0
  117. package/prisma/skills/continuous-learning/evaluate-session.sh +69 -0
  118. package/prisma/skills/continuous-learning-v2/SKILL.md +361 -0
  119. package/prisma/skills/continuous-learning-v2/agents/observer-loop.sh +359 -0
  120. package/prisma/skills/continuous-learning-v2/agents/observer.md +189 -0
  121. package/prisma/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
  122. package/prisma/skills/continuous-learning-v2/agents/start-observer.sh +248 -0
  123. package/prisma/skills/continuous-learning-v2/config.json +8 -0
  124. package/prisma/skills/continuous-learning-v2/hooks/observe.sh +585 -0
  125. package/prisma/skills/continuous-learning-v2/scripts/detect-project.sh +322 -0
  126. package/prisma/skills/continuous-learning-v2/scripts/instinct-cli.py +1956 -0
  127. package/prisma/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +31 -0
  128. package/prisma/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +68 -0
  129. package/prisma/skills/continuous-learning-v2/scripts/test_parse_instinct.py +1421 -0
  130. package/prisma/skills/cost-aware-llm-pipeline/SKILL.md +184 -0
  131. package/prisma/skills/cost-tracking/SKILL.md +97 -0
  132. package/prisma/skills/council/SKILL.md +204 -0
  133. package/prisma/skills/cpp-coding-standards/SKILL.md +724 -0
  134. package/prisma/skills/cpp-testing/SKILL.md +325 -0
  135. package/prisma/skills/crosspost/SKILL.md +112 -0
  136. package/prisma/skills/csharp-testing/SKILL.md +322 -0
  137. package/prisma/skills/customer-billing-ops/SKILL.md +141 -0
  138. package/prisma/skills/customs-trade-compliance/SKILL.md +263 -0
  139. package/prisma/skills/dart-flutter-patterns/SKILL.md +564 -0
  140. package/prisma/skills/dashboard-builder/SKILL.md +109 -0
  141. package/prisma/skills/data-scraper-agent/SKILL.md +765 -0
  142. package/prisma/skills/data-throughput-accelerator/SKILL.md +73 -0
  143. package/prisma/skills/database-migrations/SKILL.md +430 -0
  144. package/prisma/skills/deep-research/SKILL.md +160 -0
  145. package/prisma/skills/defi-amm-security/SKILL.md +167 -0
  146. package/prisma/skills/delivery-gate/SKILL.md +126 -0
  147. package/prisma/skills/delivery-gate/hooks/quality-gate.py +220 -0
  148. package/prisma/skills/deployment-patterns/SKILL.md +428 -0
  149. package/prisma/skills/design-system/SKILL.md +83 -0
  150. package/prisma/skills/django-celery/SKILL.md +458 -0
  151. package/prisma/skills/django-patterns/SKILL.md +735 -0
  152. package/prisma/skills/django-security/SKILL.md +644 -0
  153. package/prisma/skills/django-tdd/SKILL.md +730 -0
  154. package/prisma/skills/django-verification/SKILL.md +470 -0
  155. package/prisma/skills/dmux-workflows/SKILL.md +192 -0
  156. package/prisma/skills/docker-patterns/SKILL.md +365 -0
  157. package/prisma/skills/documentation-lookup/SKILL.md +91 -0
  158. package/prisma/skills/dotnet-patterns/SKILL.md +322 -0
  159. package/prisma/skills/dynamic-workflow-mode/SKILL.md +124 -0
  160. package/prisma/skills/e2e-testing/SKILL.md +327 -0
  161. package/prisma/skills/ecc-guide/SKILL.md +190 -0
  162. package/prisma/skills/ecc-recipes/SKILL.md +149 -0
  163. package/prisma/skills/ecc-tools-cost-audit/SKILL.md +161 -0
  164. package/prisma/skills/email-ops/SKILL.md +122 -0
  165. package/prisma/skills/energy-procurement/SKILL.md +228 -0
  166. package/prisma/skills/enterprise-agent-ops/SKILL.md +51 -0
  167. package/prisma/skills/error-handling/SKILL.md +377 -0
  168. package/prisma/skills/eval-harness/SKILL.md +271 -0
  169. package/prisma/skills/evm-token-decimals/SKILL.md +131 -0
  170. package/prisma/skills/exa-search/SKILL.md +108 -0
  171. package/prisma/skills/fal-ai-media/SKILL.md +289 -0
  172. package/prisma/skills/fastapi-patterns/SKILL.md +514 -0
  173. package/prisma/skills/finance-billing-ops/SKILL.md +128 -0
  174. package/prisma/skills/flox-environments/SKILL.md +497 -0
  175. package/prisma/skills/flutter-dart-code-review/SKILL.md +436 -0
  176. package/prisma/skills/foundation-models-on-device/SKILL.md +243 -0
  177. package/prisma/skills/frontend-a11y/SKILL.md +446 -0
  178. package/prisma/skills/frontend-design-direction/SKILL.md +93 -0
  179. package/prisma/skills/frontend-patterns/SKILL.md +657 -0
  180. package/prisma/skills/frontend-slides/SKILL.md +185 -0
  181. package/prisma/skills/frontend-slides/STYLE_PRESETS.md +330 -0
  182. package/prisma/skills/frontend-slides/animation-patterns.md +122 -0
  183. package/prisma/skills/frontend-slides/html-template.md +419 -0
  184. package/prisma/skills/frontend-slides/scripts/export-pdf.sh +418 -0
  185. package/prisma/skills/frontend-slides/scripts/extract-pptx.py +96 -0
  186. package/prisma/skills/frontend-slides/viewport-base.css +153 -0
  187. package/prisma/skills/fsharp-testing/SKILL.md +281 -0
  188. package/prisma/skills/gan-style-harness/SKILL.md +279 -0
  189. package/prisma/skills/gateguard/SKILL.md +133 -0
  190. package/prisma/skills/generating-python-installer/SKILL.md +820 -0
  191. package/prisma/skills/git-workflow/SKILL.md +716 -0
  192. package/prisma/skills/github-ops/SKILL.md +145 -0
  193. package/prisma/skills/golang-patterns/SKILL.md +675 -0
  194. package/prisma/skills/golang-testing/SKILL.md +721 -0
  195. package/prisma/skills/google-workspace-ops/SKILL.md +96 -0
  196. package/prisma/skills/growth-log/SKILL.md +128 -0
  197. package/prisma/skills/healthcare-cdss-patterns/SKILL.md +246 -0
  198. package/prisma/skills/healthcare-emr-patterns/SKILL.md +160 -0
  199. package/prisma/skills/healthcare-eval-harness/SKILL.md +208 -0
  200. package/prisma/skills/healthcare-phi-compliance/SKILL.md +146 -0
  201. package/prisma/skills/hermes-imports/SKILL.md +89 -0
  202. package/prisma/skills/hexagonal-architecture/SKILL.md +277 -0
  203. package/prisma/skills/hipaa-compliance/SKILL.md +79 -0
  204. package/prisma/skills/homelab-network-readiness/SKILL.md +170 -0
  205. package/prisma/skills/homelab-network-setup/SKILL.md +130 -0
  206. package/prisma/skills/homelab-pihole-dns/SKILL.md +275 -0
  207. package/prisma/skills/homelab-vlan-segmentation/SKILL.md +312 -0
  208. package/prisma/skills/homelab-wireguard-vpn/SKILL.md +306 -0
  209. package/prisma/skills/hookify-rules/SKILL.md +128 -0
  210. package/prisma/skills/inherit-legacy-style/SKILL.md +157 -0
  211. package/prisma/skills/intent-driven-development/SKILL.md +360 -0
  212. package/prisma/skills/inventory-demand-planning/SKILL.md +247 -0
  213. package/prisma/skills/investor-materials/SKILL.md +97 -0
  214. package/prisma/skills/investor-outreach/SKILL.md +92 -0
  215. package/prisma/skills/ios-icon-gen/SKILL.md +158 -0
  216. package/prisma/skills/ios-icon-gen/scripts/generate_icons.swift +258 -0
  217. package/prisma/skills/ios-icon-gen/scripts/iconify_gen.sh +235 -0
  218. package/prisma/skills/iterative-retrieval/SKILL.md +212 -0
  219. package/prisma/skills/ito-basket-compare/SKILL.md +64 -0
  220. package/prisma/skills/ito-data-atlas-agent/SKILL.md +64 -0
  221. package/prisma/skills/ito-market-intelligence/SKILL.md +61 -0
  222. package/prisma/skills/ito-trade-planner/SKILL.md +68 -0
  223. package/prisma/skills/java-coding-standards/SKILL.md +384 -0
  224. package/prisma/skills/jira-integration/SKILL.md +303 -0
  225. package/prisma/skills/jpa-patterns/SKILL.md +152 -0
  226. package/prisma/skills/knowledge-ops/SKILL.md +155 -0
  227. package/prisma/skills/kotlin-coroutines-flows/SKILL.md +285 -0
  228. package/prisma/skills/kotlin-exposed-patterns/SKILL.md +720 -0
  229. package/prisma/skills/kotlin-ktor-patterns/SKILL.md +690 -0
  230. package/prisma/skills/kotlin-patterns/SKILL.md +712 -0
  231. package/prisma/skills/kotlin-testing/SKILL.md +825 -0
  232. package/prisma/skills/kubernetes-patterns/SKILL.md +756 -0
  233. package/prisma/skills/laravel-patterns/SKILL.md +416 -0
  234. package/prisma/skills/laravel-plugin-discovery/SKILL.md +230 -0
  235. package/prisma/skills/laravel-security/SKILL.md +948 -0
  236. package/prisma/skills/laravel-tdd/SKILL.md +675 -0
  237. package/prisma/skills/laravel-verification/SKILL.md +180 -0
  238. package/prisma/skills/latency-critical-systems/SKILL.md +74 -0
  239. package/prisma/skills/lead-intelligence/SKILL.md +322 -0
  240. package/prisma/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
  241. package/prisma/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
  242. package/prisma/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
  243. package/prisma/skills/lead-intelligence/agents/signal-scorer.md +60 -0
  244. package/prisma/skills/liquid-glass-design/SKILL.md +279 -0
  245. package/prisma/skills/llm-trading-agent-security/SKILL.md +147 -0
  246. package/prisma/skills/logistics-exception-management/SKILL.md +222 -0
  247. package/prisma/skills/loop-design-check/SKILL.md +143 -0
  248. package/prisma/skills/mailtrap-email-integration/SKILL.md +77 -0
  249. package/prisma/skills/make-interfaces-feel-better/SKILL.md +152 -0
  250. package/prisma/skills/manim-video/SKILL.md +90 -0
  251. package/prisma/skills/manim-video/assets/network_graph_scene.py +52 -0
  252. package/prisma/skills/market-research/SKILL.md +76 -0
  253. package/prisma/skills/marketing-campaign/SKILL.md +114 -0
  254. package/prisma/skills/mcp-server-patterns/SKILL.md +70 -0
  255. package/prisma/skills/messages-ops/SKILL.md +105 -0
  256. package/prisma/skills/ml-adoption-playbook/SKILL.md +57 -0
  257. package/prisma/skills/mle-workflow/SKILL.md +347 -0
  258. package/prisma/skills/motion-advanced/SKILL.md +596 -0
  259. package/prisma/skills/motion-foundations/SKILL.md +299 -0
  260. package/prisma/skills/motion-patterns/SKILL.md +434 -0
  261. package/prisma/skills/motion-ui/SKILL.md +576 -0
  262. package/prisma/skills/mysql-patterns/SKILL.md +413 -0
  263. package/prisma/skills/nanoclaw-repl/SKILL.md +34 -0
  264. package/prisma/skills/nestjs-patterns/SKILL.md +231 -0
  265. package/prisma/skills/netmiko-ssh-automation/SKILL.md +174 -0
  266. package/prisma/skills/network-bgp-diagnostics/SKILL.md +168 -0
  267. package/prisma/skills/network-config-validation/SKILL.md +211 -0
  268. package/prisma/skills/network-interface-health/SKILL.md +153 -0
  269. package/prisma/skills/nextjs-turbopack/SKILL.md +58 -0
  270. package/prisma/skills/nodejs-keccak256/SKILL.md +103 -0
  271. package/prisma/skills/nutrient-document-processing/SKILL.md +168 -0
  272. package/prisma/skills/nuxt4-patterns/SKILL.md +101 -0
  273. package/prisma/skills/openclaw-persona-forge/SKILL.md +289 -0
  274. package/prisma/skills/openclaw-persona-forge/gacha.py +224 -0
  275. package/prisma/skills/openclaw-persona-forge/gacha.sh +5 -0
  276. package/prisma/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
  277. package/prisma/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
  278. package/prisma/skills/openclaw-persona-forge/references/error-handling.md +53 -0
  279. package/prisma/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
  280. package/prisma/skills/openclaw-persona-forge/references/naming-system.md +39 -0
  281. package/prisma/skills/openclaw-persona-forge/references/output-template.md +166 -0
  282. package/prisma/skills/opensource-pipeline/SKILL.md +256 -0
  283. package/prisma/skills/orch-add-feature/SKILL.md +45 -0
  284. package/prisma/skills/orch-build-mvp/SKILL.md +49 -0
  285. package/prisma/skills/orch-change-feature/SKILL.md +43 -0
  286. package/prisma/skills/orch-fix-defect/SKILL.md +43 -0
  287. package/prisma/skills/orch-pipeline/SKILL.md +121 -0
  288. package/prisma/skills/orch-refine-code/SKILL.md +44 -0
  289. package/prisma/skills/parallel-execution-optimizer/SKILL.md +73 -0
  290. package/prisma/skills/perl-patterns/SKILL.md +505 -0
  291. package/prisma/skills/perl-security/SKILL.md +504 -0
  292. package/prisma/skills/perl-testing/SKILL.md +476 -0
  293. package/prisma/skills/plan-orchestrate/SKILL.md +263 -0
  294. package/prisma/skills/plankton-code-quality/SKILL.md +237 -0
  295. package/prisma/skills/postgres-patterns/SKILL.md +148 -0
  296. package/prisma/skills/prediction-market-oracle-research/SKILL.md +64 -0
  297. package/prisma/skills/prediction-market-risk-review/SKILL.md +61 -0
  298. package/prisma/skills/prisma-patterns/SKILL.md +401 -0
  299. package/prisma/skills/product-capability/SKILL.md +142 -0
  300. package/prisma/skills/product-lens/SKILL.md +93 -0
  301. package/prisma/skills/production-audit/SKILL.md +207 -0
  302. package/prisma/skills/production-scheduling/SKILL.md +238 -0
  303. package/prisma/skills/project-flow-ops/SKILL.md +112 -0
  304. package/prisma/skills/prompt-optimizer/SKILL.md +398 -0
  305. package/prisma/skills/python-patterns/SKILL.md +751 -0
  306. package/prisma/skills/python-testing/SKILL.md +817 -0
  307. package/prisma/skills/pytorch-patterns/SKILL.md +397 -0
  308. package/prisma/skills/quality-nonconformance/SKILL.md +260 -0
  309. package/prisma/skills/quarkus-patterns/SKILL.md +723 -0
  310. package/prisma/skills/quarkus-security/SKILL.md +468 -0
  311. package/prisma/skills/quarkus-tdd/SKILL.md +812 -0
  312. package/prisma/skills/quarkus-verification/SKILL.md +480 -0
  313. package/prisma/skills/ralphinho-rfc-pipeline/SKILL.md +68 -0
  314. package/prisma/skills/react-native-patterns/SKILL.md +326 -0
  315. package/prisma/skills/react-patterns/SKILL.md +342 -0
  316. package/prisma/skills/react-performance/SKILL.md +575 -0
  317. package/prisma/skills/react-testing/SKILL.md +424 -0
  318. package/prisma/skills/recsys-pipeline-architect/SKILL.md +115 -0
  319. package/prisma/skills/recursive-decision-ledger/SKILL.md +80 -0
  320. package/prisma/skills/redis-patterns/SKILL.md +404 -0
  321. package/prisma/skills/regex-vs-llm-structured-text/SKILL.md +221 -0
  322. package/prisma/skills/remotion-video-creation/SKILL.md +43 -0
  323. package/prisma/skills/remotion-video-creation/rules/3d.md +86 -0
  324. package/prisma/skills/remotion-video-creation/rules/animations.md +29 -0
  325. package/prisma/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
  326. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
  327. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
  328. package/prisma/skills/remotion-video-creation/rules/assets.md +78 -0
  329. package/prisma/skills/remotion-video-creation/rules/audio.md +172 -0
  330. package/prisma/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
  331. package/prisma/skills/remotion-video-creation/rules/can-decode.md +75 -0
  332. package/prisma/skills/remotion-video-creation/rules/charts.md +58 -0
  333. package/prisma/skills/remotion-video-creation/rules/compositions.md +146 -0
  334. package/prisma/skills/remotion-video-creation/rules/display-captions.md +126 -0
  335. package/prisma/skills/remotion-video-creation/rules/extract-frames.md +229 -0
  336. package/prisma/skills/remotion-video-creation/rules/fonts.md +152 -0
  337. package/prisma/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
  338. package/prisma/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
  339. package/prisma/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
  340. package/prisma/skills/remotion-video-creation/rules/gifs.md +138 -0
  341. package/prisma/skills/remotion-video-creation/rules/images.md +130 -0
  342. package/prisma/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
  343. package/prisma/skills/remotion-video-creation/rules/lottie.md +67 -0
  344. package/prisma/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
  345. package/prisma/skills/remotion-video-creation/rules/measuring-text.md +143 -0
  346. package/prisma/skills/remotion-video-creation/rules/sequencing.md +106 -0
  347. package/prisma/skills/remotion-video-creation/rules/tailwind.md +11 -0
  348. package/prisma/skills/remotion-video-creation/rules/text-animations.md +20 -0
  349. package/prisma/skills/remotion-video-creation/rules/timing.md +179 -0
  350. package/prisma/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
  351. package/prisma/skills/remotion-video-creation/rules/transitions.md +122 -0
  352. package/prisma/skills/remotion-video-creation/rules/trimming.md +52 -0
  353. package/prisma/skills/remotion-video-creation/rules/videos.md +171 -0
  354. package/prisma/skills/repo-scan/SKILL.md +79 -0
  355. package/prisma/skills/research-ops/SKILL.md +113 -0
  356. package/prisma/skills/returns-reverse-logistics/SKILL.md +240 -0
  357. package/prisma/skills/rules-distill/SKILL.md +265 -0
  358. package/prisma/skills/rules-distill/scripts/scan-rules.sh +58 -0
  359. package/prisma/skills/rules-distill/scripts/scan-skills.sh +129 -0
  360. package/prisma/skills/rust-patterns/SKILL.md +500 -0
  361. package/prisma/skills/rust-testing/SKILL.md +501 -0
  362. package/prisma/skills/safety-guard/SKILL.md +76 -0
  363. package/prisma/skills/santa-method/SKILL.md +307 -0
  364. package/prisma/skills/scientific-db-pubmed-database/SKILL.md +176 -0
  365. package/prisma/skills/scientific-db-uspto-database/SKILL.md +178 -0
  366. package/prisma/skills/scientific-pkg-gget/SKILL.md +167 -0
  367. package/prisma/skills/scientific-thinking-literature-review/SKILL.md +193 -0
  368. package/prisma/skills/scientific-thinking-scholar-evaluation/SKILL.md +161 -0
  369. package/prisma/skills/search-first/SKILL.md +183 -0
  370. package/prisma/skills/security-bounty-hunter/SKILL.md +100 -0
  371. package/prisma/skills/security-review/SKILL.md +504 -0
  372. package/prisma/skills/security-review/cloud-infrastructure-security.md +361 -0
  373. package/prisma/skills/security-scan/SKILL.md +166 -0
  374. package/prisma/skills/seo/SKILL.md +155 -0
  375. package/prisma/skills/skill-comply/SKILL.md +59 -0
  376. package/prisma/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
  377. package/prisma/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
  378. package/prisma/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
  379. package/prisma/skills/skill-comply/prompts/classifier.md +24 -0
  380. package/prisma/skills/skill-comply/prompts/scenario_generator.md +62 -0
  381. package/prisma/skills/skill-comply/prompts/spec_generator.md +42 -0
  382. package/prisma/skills/skill-comply/pyproject.toml +15 -0
  383. package/prisma/skills/skill-comply/scripts/__init__.py +0 -0
  384. package/prisma/skills/skill-comply/scripts/classifier.py +85 -0
  385. package/prisma/skills/skill-comply/scripts/grader.py +124 -0
  386. package/prisma/skills/skill-comply/scripts/parser.py +107 -0
  387. package/prisma/skills/skill-comply/scripts/report.py +170 -0
  388. package/prisma/skills/skill-comply/scripts/run.py +127 -0
  389. package/prisma/skills/skill-comply/scripts/runner.py +194 -0
  390. package/prisma/skills/skill-comply/scripts/scenario_generator.py +70 -0
  391. package/prisma/skills/skill-comply/scripts/spec_generator.py +72 -0
  392. package/prisma/skills/skill-comply/scripts/utils.py +13 -0
  393. package/prisma/skills/skill-comply/tests/test_grader.py +197 -0
  394. package/prisma/skills/skill-comply/tests/test_parser.py +90 -0
  395. package/prisma/skills/skill-comply/tests/test_runner.py +172 -0
  396. package/prisma/skills/skill-scout/SKILL.md +141 -0
  397. package/prisma/skills/skill-stocktake/SKILL.md +195 -0
  398. package/prisma/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
  399. package/prisma/skills/skill-stocktake/scripts/save-results.sh +56 -0
  400. package/prisma/skills/skill-stocktake/scripts/scan.sh +170 -0
  401. package/prisma/skills/social-graph-ranker/SKILL.md +155 -0
  402. package/prisma/skills/social-publisher/SKILL.md +130 -0
  403. package/prisma/skills/springboot-patterns/SKILL.md +315 -0
  404. package/prisma/skills/springboot-security/SKILL.md +273 -0
  405. package/prisma/skills/springboot-tdd/SKILL.md +159 -0
  406. package/prisma/skills/springboot-verification/SKILL.md +232 -0
  407. package/prisma/skills/strategic-compact/SKILL.md +136 -0
  408. package/prisma/skills/swift-actor-persistence/SKILL.md +144 -0
  409. package/prisma/skills/swift-concurrency-6-2/SKILL.md +216 -0
  410. package/prisma/skills/swift-protocol-di-testing/SKILL.md +191 -0
  411. package/prisma/skills/swiftui-patterns/SKILL.md +259 -0
  412. package/prisma/skills/taste/SKILL.md +264 -0
  413. package/prisma/skills/taste/references/genre-taxonomy.md +87 -0
  414. package/prisma/skills/tdd-workflow/SKILL.md +583 -0
  415. package/prisma/skills/team-agent-orchestration/SKILL.md +111 -0
  416. package/prisma/skills/team-builder/SKILL.md +169 -0
  417. package/prisma/skills/terminal-ops/SKILL.md +110 -0
  418. package/prisma/skills/tinystruct-patterns/SKILL.md +279 -0
  419. package/prisma/skills/tinystruct-patterns/references/architecture.md +90 -0
  420. package/prisma/skills/tinystruct-patterns/references/data-handling.md +60 -0
  421. package/prisma/skills/tinystruct-patterns/references/database.md +99 -0
  422. package/prisma/skills/tinystruct-patterns/references/routing.md +64 -0
  423. package/prisma/skills/tinystruct-patterns/references/system-usage.md +97 -0
  424. package/prisma/skills/tinystruct-patterns/references/testing.md +72 -0
  425. package/prisma/skills/token-budget-advisor/SKILL.md +134 -0
  426. package/prisma/skills/ui-demo/SKILL.md +466 -0
  427. package/prisma/skills/ui-to-vue/SKILL.md +135 -0
  428. package/prisma/skills/uncloud/SKILL.md +344 -0
  429. package/prisma/skills/unified-notifications-ops/SKILL.md +188 -0
  430. package/prisma/skills/verification-loop/SKILL.md +127 -0
  431. package/prisma/skills/video-editing/SKILL.md +311 -0
  432. package/prisma/skills/videodb/SKILL.md +375 -0
  433. package/prisma/skills/videodb/reference/api-reference.md +550 -0
  434. package/prisma/skills/videodb/reference/capture-reference.md +407 -0
  435. package/prisma/skills/videodb/reference/capture.md +101 -0
  436. package/prisma/skills/videodb/reference/editor.md +443 -0
  437. package/prisma/skills/videodb/reference/generative.md +331 -0
  438. package/prisma/skills/videodb/reference/rtstream-reference.md +564 -0
  439. package/prisma/skills/videodb/reference/rtstream.md +65 -0
  440. package/prisma/skills/videodb/reference/search.md +230 -0
  441. package/prisma/skills/videodb/reference/streaming.md +406 -0
  442. package/prisma/skills/videodb/reference/use-cases.md +118 -0
  443. package/prisma/skills/videodb/scripts/ws_listener.py +282 -0
  444. package/prisma/skills/visa-doc-translate/README.md +86 -0
  445. package/prisma/skills/visa-doc-translate/SKILL.md +117 -0
  446. package/prisma/skills/vite-patterns/SKILL.md +450 -0
  447. package/prisma/skills/vue-patterns/SKILL.md +471 -0
  448. package/prisma/skills/windows-desktop-e2e/SKILL.md +888 -0
  449. package/prisma/skills/workspace-surface-audit/SKILL.md +126 -0
  450. package/prisma/skills/x-api/SKILL.md +235 -0
  451. package/run.mjs +0 -10
@@ -0,0 +1,735 @@
1
+ ---
2
+ name: django-patterns
3
+ description: Django architecture patterns, REST API design with DRF, ORM best practices, caching, signals, middleware, and production-grade Django apps.
4
+ metadata:
5
+ origin: ECC
6
+ ---
7
+
8
+ # Django Development Patterns
9
+
10
+ Production-grade Django architecture patterns for scalable, maintainable applications.
11
+
12
+ ## When to Activate
13
+
14
+ - Building Django web applications
15
+ - Designing Django REST Framework APIs
16
+ - Working with Django ORM and models
17
+ - Setting up Django project structure
18
+ - Implementing caching, signals, middleware
19
+
20
+ ## Project Structure
21
+
22
+ ### Recommended Layout
23
+
24
+ ```
25
+ myproject/
26
+ ├── config/
27
+ │ ├── __init__.py
28
+ │ ├── settings/
29
+ │ │ ├── __init__.py
30
+ │ │ ├── base.py # Base settings
31
+ │ │ ├── development.py # Dev settings
32
+ │ │ ├── production.py # Production settings
33
+ │ │ └── test.py # Test settings
34
+ │ ├── urls.py
35
+ │ ├── wsgi.py
36
+ │ └── asgi.py
37
+ ├── manage.py
38
+ └── apps/
39
+ ├── __init__.py
40
+ ├── users/
41
+ │ ├── __init__.py
42
+ │ ├── models.py
43
+ │ ├── views.py
44
+ │ ├── serializers.py
45
+ │ ├── urls.py
46
+ │ ├── permissions.py
47
+ │ ├── filters.py
48
+ │ ├── services.py
49
+ │ └── tests/
50
+ └── products/
51
+ └── ...
52
+ ```
53
+
54
+ ### Split Settings Pattern
55
+
56
+ ```python
57
+ # config/settings/base.py
58
+ from pathlib import Path
59
+
60
+ BASE_DIR = Path(__file__).resolve().parent.parent.parent
61
+
62
+ SECRET_KEY = env('DJANGO_SECRET_KEY')
63
+ DEBUG = False
64
+ ALLOWED_HOSTS = []
65
+
66
+ INSTALLED_APPS = [
67
+ 'django.contrib.admin',
68
+ 'django.contrib.auth',
69
+ 'django.contrib.contenttypes',
70
+ 'django.contrib.sessions',
71
+ 'django.contrib.messages',
72
+ 'django.contrib.staticfiles',
73
+ 'rest_framework',
74
+ 'rest_framework.authtoken',
75
+ 'corsheaders',
76
+ # Local apps
77
+ 'apps.users',
78
+ 'apps.products',
79
+ ]
80
+
81
+ MIDDLEWARE = [
82
+ 'django.middleware.security.SecurityMiddleware',
83
+ 'whitenoise.middleware.WhiteNoiseMiddleware',
84
+ 'django.contrib.sessions.middleware.SessionMiddleware',
85
+ 'corsheaders.middleware.CorsMiddleware',
86
+ 'django.middleware.common.CommonMiddleware',
87
+ 'django.middleware.csrf.CsrfViewMiddleware',
88
+ 'django.contrib.auth.middleware.AuthenticationMiddleware',
89
+ 'django.contrib.messages.middleware.MessageMiddleware',
90
+ 'django.middleware.clickjacking.XFrameOptionsMiddleware',
91
+ ]
92
+
93
+ ROOT_URLCONF = 'config.urls'
94
+ WSGI_APPLICATION = 'config.wsgi.application'
95
+
96
+ DATABASES = {
97
+ 'default': {
98
+ 'ENGINE': 'django.db.backends.postgresql',
99
+ 'NAME': env('DB_NAME'),
100
+ 'USER': env('DB_USER'),
101
+ 'PASSWORD': env('DB_PASSWORD'),
102
+ 'HOST': env('DB_HOST'),
103
+ 'PORT': env('DB_PORT', default='5432'),
104
+ }
105
+ }
106
+
107
+ # config/settings/development.py
108
+ from .base import *
109
+
110
+ DEBUG = True
111
+ ALLOWED_HOSTS = ['localhost', '127.0.0.1']
112
+
113
+ DATABASES['default']['NAME'] = 'myproject_dev'
114
+
115
+ INSTALLED_APPS += ['debug_toolbar']
116
+
117
+ MIDDLEWARE += ['debug_toolbar.middleware.DebugToolbarMiddleware']
118
+
119
+ EMAIL_BACKEND = 'django.core.mail.backends.console.EmailBackend'
120
+
121
+ # config/settings/production.py
122
+ from .base import *
123
+
124
+ DEBUG = False
125
+ ALLOWED_HOSTS = env.list('ALLOWED_HOSTS')
126
+ SECURE_SSL_REDIRECT = True
127
+ SESSION_COOKIE_SECURE = True
128
+ CSRF_COOKIE_SECURE = True
129
+ SECURE_HSTS_SECONDS = 31536000
130
+ SECURE_HSTS_INCLUDE_SUBDOMAINS = True
131
+ SECURE_HSTS_PRELOAD = True
132
+
133
+ # Logging
134
+ LOGGING = {
135
+ 'version': 1,
136
+ 'disable_existing_loggers': False,
137
+ 'handlers': {
138
+ 'file': {
139
+ 'level': 'WARNING',
140
+ 'class': 'logging.FileHandler',
141
+ 'filename': '/var/log/django/django.log',
142
+ },
143
+ },
144
+ 'loggers': {
145
+ 'django': {
146
+ 'handlers': ['file'],
147
+ 'level': 'WARNING',
148
+ 'propagate': True,
149
+ },
150
+ },
151
+ }
152
+ ```
153
+
154
+ ## Model Design Patterns
155
+
156
+ ### Model Best Practices
157
+
158
+ ```python
159
+ from django.db import models
160
+ from django.contrib.auth.models import AbstractUser
161
+ from django.core.validators import MinValueValidator, MaxValueValidator
162
+
163
+ class User(AbstractUser):
164
+ """Custom user model extending AbstractUser."""
165
+ email = models.EmailField(unique=True)
166
+ phone = models.CharField(max_length=20, blank=True)
167
+ birth_date = models.DateField(null=True, blank=True)
168
+
169
+ USERNAME_FIELD = 'email'
170
+ REQUIRED_FIELDS = ['username']
171
+
172
+ class Meta:
173
+ db_table = 'users'
174
+ verbose_name = 'user'
175
+ verbose_name_plural = 'users'
176
+ ordering = ['-date_joined']
177
+
178
+ def __str__(self):
179
+ return self.email
180
+
181
+ def get_full_name(self):
182
+ return f"{self.first_name} {self.last_name}".strip()
183
+
184
+ class Product(models.Model):
185
+ """Product model with proper field configuration."""
186
+ name = models.CharField(max_length=200)
187
+ slug = models.SlugField(unique=True, max_length=250)
188
+ description = models.TextField(blank=True)
189
+ price = models.DecimalField(
190
+ max_digits=10,
191
+ decimal_places=2,
192
+ validators=[MinValueValidator(0)]
193
+ )
194
+ stock = models.PositiveIntegerField(default=0)
195
+ is_active = models.BooleanField(default=True)
196
+ category = models.ForeignKey(
197
+ 'Category',
198
+ on_delete=models.CASCADE,
199
+ related_name='products'
200
+ )
201
+ tags = models.ManyToManyField('Tag', blank=True, related_name='products')
202
+ created_at = models.DateTimeField(auto_now_add=True)
203
+ updated_at = models.DateTimeField(auto_now=True)
204
+
205
+ class Meta:
206
+ db_table = 'products'
207
+ ordering = ['-created_at']
208
+ indexes = [
209
+ models.Index(fields=['slug']),
210
+ models.Index(fields=['-created_at']),
211
+ models.Index(fields=['category', 'is_active']),
212
+ ]
213
+ constraints = [
214
+ models.CheckConstraint(
215
+ check=models.Q(price__gte=0),
216
+ name='price_non_negative'
217
+ )
218
+ ]
219
+
220
+ def __str__(self):
221
+ return self.name
222
+
223
+ def save(self, *args, **kwargs):
224
+ if not self.slug:
225
+ self.slug = slugify(self.name)
226
+ super().save(*args, **kwargs)
227
+ ```
228
+
229
+ ### QuerySet Best Practices
230
+
231
+ ```python
232
+ from django.db import models
233
+
234
+ class ProductQuerySet(models.QuerySet):
235
+ """Custom QuerySet for Product model."""
236
+
237
+ def active(self):
238
+ """Return only active products."""
239
+ return self.filter(is_active=True)
240
+
241
+ def with_category(self):
242
+ """Select related category to avoid N+1 queries."""
243
+ return self.select_related('category')
244
+
245
+ def with_tags(self):
246
+ """Prefetch tags for many-to-many relationship."""
247
+ return self.prefetch_related('tags')
248
+
249
+ def in_stock(self):
250
+ """Return products with stock > 0."""
251
+ return self.filter(stock__gt=0)
252
+
253
+ def search(self, query):
254
+ """Search products by name or description."""
255
+ return self.filter(
256
+ models.Q(name__icontains=query) |
257
+ models.Q(description__icontains=query)
258
+ )
259
+
260
+ class Product(models.Model):
261
+ # ... fields ...
262
+
263
+ objects = ProductQuerySet.as_manager() # Use custom QuerySet
264
+
265
+ # Usage
266
+ Product.objects.active().with_category().in_stock()
267
+ ```
268
+
269
+ ### Manager Methods
270
+
271
+ ```python
272
+ class ProductManager(models.Manager):
273
+ """Custom manager for complex queries."""
274
+
275
+ def get_or_none(self, **kwargs):
276
+ """Return object or None instead of DoesNotExist."""
277
+ try:
278
+ return self.get(**kwargs)
279
+ except self.model.DoesNotExist:
280
+ return None
281
+
282
+ def create_with_tags(self, name, price, tag_names):
283
+ """Create product with associated tags."""
284
+ product = self.create(name=name, price=price)
285
+ tags = [Tag.objects.get_or_create(name=name)[0] for name in tag_names]
286
+ product.tags.set(tags)
287
+ return product
288
+
289
+ def bulk_update_stock(self, product_ids, quantity):
290
+ """Bulk update stock for multiple products."""
291
+ return self.filter(id__in=product_ids).update(stock=quantity)
292
+
293
+ # In model
294
+ class Product(models.Model):
295
+ # ... fields ...
296
+ custom = ProductManager()
297
+ ```
298
+
299
+ ## Django REST Framework Patterns
300
+
301
+ ### Serializer Patterns
302
+
303
+ ```python
304
+ from rest_framework import serializers
305
+ from django.contrib.auth.password_validation import validate_password
306
+ from .models import Product, User
307
+
308
+ class ProductSerializer(serializers.ModelSerializer):
309
+ """Serializer for Product model."""
310
+
311
+ category_name = serializers.CharField(source='category.name', read_only=True)
312
+ average_rating = serializers.FloatField(read_only=True)
313
+ discount_price = serializers.SerializerMethodField()
314
+
315
+ class Meta:
316
+ model = Product
317
+ fields = [
318
+ 'id', 'name', 'slug', 'description', 'price',
319
+ 'discount_price', 'stock', 'category_name',
320
+ 'average_rating', 'created_at'
321
+ ]
322
+ read_only_fields = ['id', 'slug', 'created_at']
323
+
324
+ def get_discount_price(self, obj):
325
+ """Calculate discount price if applicable."""
326
+ if hasattr(obj, 'discount') and obj.discount:
327
+ return obj.price * (1 - obj.discount.percent / 100)
328
+ return obj.price
329
+
330
+ def validate_price(self, value):
331
+ """Ensure price is non-negative."""
332
+ if value < 0:
333
+ raise serializers.ValidationError("Price cannot be negative.")
334
+ return value
335
+
336
+ class ProductCreateSerializer(serializers.ModelSerializer):
337
+ """Serializer for creating products."""
338
+
339
+ class Meta:
340
+ model = Product
341
+ fields = ['name', 'description', 'price', 'stock', 'category']
342
+
343
+ def validate(self, data):
344
+ """Custom validation for multiple fields."""
345
+ if data['price'] > 10000 and data['stock'] > 100:
346
+ raise serializers.ValidationError(
347
+ "Cannot have high-value products with large stock."
348
+ )
349
+ return data
350
+
351
+ class UserRegistrationSerializer(serializers.ModelSerializer):
352
+ """Serializer for user registration."""
353
+
354
+ password = serializers.CharField(
355
+ write_only=True,
356
+ required=True,
357
+ validators=[validate_password],
358
+ style={'input_type': 'password'}
359
+ )
360
+ password_confirm = serializers.CharField(write_only=True, style={'input_type': 'password'})
361
+
362
+ class Meta:
363
+ model = User
364
+ fields = ['email', 'username', 'password', 'password_confirm']
365
+
366
+ def validate(self, data):
367
+ """Validate passwords match."""
368
+ if data['password'] != data['password_confirm']:
369
+ raise serializers.ValidationError({
370
+ "password_confirm": "Password fields didn't match."
371
+ })
372
+ return data
373
+
374
+ def create(self, validated_data):
375
+ """Create user with hashed password."""
376
+ validated_data.pop('password_confirm')
377
+ password = validated_data.pop('password')
378
+ user = User.objects.create(**validated_data)
379
+ user.set_password(password)
380
+ user.save()
381
+ return user
382
+ ```
383
+
384
+ ### ViewSet Patterns
385
+
386
+ ```python
387
+ from rest_framework import viewsets, status, filters
388
+ from rest_framework.decorators import action
389
+ from rest_framework.response import Response
390
+ from rest_framework.permissions import IsAuthenticated, IsAdminUser
391
+ from django_filters.rest_framework import DjangoFilterBackend
392
+ from .models import Product
393
+ from .serializers import ProductSerializer, ProductCreateSerializer
394
+ from .permissions import IsOwnerOrReadOnly
395
+ from .filters import ProductFilter
396
+ from .services import ProductService
397
+
398
+ class ProductViewSet(viewsets.ModelViewSet):
399
+ """ViewSet for Product model."""
400
+
401
+ queryset = Product.objects.select_related('category').prefetch_related('tags')
402
+ permission_classes = [IsAuthenticated, IsOwnerOrReadOnly]
403
+ filter_backends = [DjangoFilterBackend, filters.SearchFilter, filters.OrderingFilter]
404
+ filterset_class = ProductFilter
405
+ search_fields = ['name', 'description']
406
+ ordering_fields = ['price', 'created_at', 'name']
407
+ ordering = ['-created_at']
408
+
409
+ def get_serializer_class(self):
410
+ """Return appropriate serializer based on action."""
411
+ if self.action == 'create':
412
+ return ProductCreateSerializer
413
+ return ProductSerializer
414
+
415
+ def perform_create(self, serializer):
416
+ """Save with user context."""
417
+ serializer.save(created_by=self.request.user)
418
+
419
+ @action(detail=False, methods=['get'])
420
+ def featured(self, request):
421
+ """Return featured products."""
422
+ featured = self.queryset.filter(is_featured=True)[:10]
423
+ serializer = self.get_serializer(featured, many=True)
424
+ return Response(serializer.data)
425
+
426
+ @action(detail=True, methods=['post'])
427
+ def purchase(self, request, pk=None):
428
+ """Purchase a product."""
429
+ product = self.get_object()
430
+ service = ProductService()
431
+ result = service.purchase(product, request.user)
432
+ return Response(result, status=status.HTTP_201_CREATED)
433
+
434
+ @action(detail=False, methods=['get'], permission_classes=[IsAuthenticated])
435
+ def my_products(self, request):
436
+ """Return products created by current user."""
437
+ products = self.queryset.filter(created_by=request.user)
438
+ page = self.paginate_queryset(products)
439
+ serializer = self.get_serializer(page, many=True)
440
+ return self.get_paginated_response(serializer.data)
441
+ ```
442
+
443
+ ### Custom Actions
444
+
445
+ ```python
446
+ from rest_framework.decorators import api_view, permission_classes
447
+ from rest_framework.permissions import IsAuthenticated
448
+ from rest_framework.response import Response
449
+
450
+ @api_view(['POST'])
451
+ @permission_classes([IsAuthenticated])
452
+ def add_to_cart(request):
453
+ """Add product to user cart."""
454
+ product_id = request.data.get('product_id')
455
+ quantity = request.data.get('quantity', 1)
456
+
457
+ try:
458
+ product = Product.objects.get(id=product_id)
459
+ except Product.DoesNotExist:
460
+ return Response(
461
+ {'error': 'Product not found'},
462
+ status=status.HTTP_404_NOT_FOUND
463
+ )
464
+
465
+ cart, _ = Cart.objects.get_or_create(user=request.user)
466
+ CartItem.objects.create(
467
+ cart=cart,
468
+ product=product,
469
+ quantity=quantity
470
+ )
471
+
472
+ return Response({'message': 'Added to cart'}, status=status.HTTP_201_CREATED)
473
+ ```
474
+
475
+ ## Service Layer Pattern
476
+
477
+ ```python
478
+ # apps/orders/services.py
479
+ from typing import Optional
480
+ from django.db import transaction
481
+ from .models import Order, OrderItem
482
+
483
+ class OrderService:
484
+ """Service layer for order-related business logic."""
485
+
486
+ @staticmethod
487
+ @transaction.atomic
488
+ def create_order(user, cart: Cart) -> Order:
489
+ """Create order from cart."""
490
+ order = Order.objects.create(
491
+ user=user,
492
+ total_price=cart.total_price
493
+ )
494
+
495
+ for item in cart.items.all():
496
+ OrderItem.objects.create(
497
+ order=order,
498
+ product=item.product,
499
+ quantity=item.quantity,
500
+ price=item.product.price
501
+ )
502
+
503
+ # Clear cart
504
+ cart.items.all().delete()
505
+
506
+ return order
507
+
508
+ @staticmethod
509
+ def process_payment(order: Order, payment_data: dict) -> bool:
510
+ """Process payment for order."""
511
+ # Integration with payment gateway
512
+ payment = PaymentGateway.charge(
513
+ amount=order.total_price,
514
+ token=payment_data['token']
515
+ )
516
+
517
+ if payment.success:
518
+ order.status = Order.Status.PAID
519
+ order.save()
520
+ # Send confirmation email
521
+ OrderService.send_confirmation_email(order)
522
+ return True
523
+
524
+ return False
525
+
526
+ @staticmethod
527
+ def send_confirmation_email(order: Order):
528
+ """Send order confirmation email."""
529
+ # Email sending logic
530
+ pass
531
+ ```
532
+
533
+ ## Caching Strategies
534
+
535
+ ### View-Level Caching
536
+
537
+ ```python
538
+ from django.views.decorators.cache import cache_page
539
+ from django.utils.decorators import method_decorator
540
+
541
+ @method_decorator(cache_page(60 * 15), name='dispatch') # 15 minutes
542
+ class ProductListView(generic.ListView):
543
+ model = Product
544
+ template_name = 'products/list.html'
545
+ context_object_name = 'products'
546
+ ```
547
+
548
+ ### Template Fragment Caching
549
+
550
+ ```django
551
+ {% load cache %}
552
+ {% cache 500 sidebar %}
553
+ ... expensive sidebar content ...
554
+ {% endcache %}
555
+ ```
556
+
557
+ ### Low-Level Caching
558
+
559
+ ```python
560
+ from django.core.cache import cache
561
+
562
+ def get_featured_products():
563
+ """Get featured products with caching."""
564
+ cache_key = 'featured_products'
565
+ products = cache.get(cache_key)
566
+
567
+ if products is None:
568
+ products = list(Product.objects.filter(is_featured=True))
569
+ cache.set(cache_key, products, timeout=60 * 15) # 15 minutes
570
+
571
+ return products
572
+ ```
573
+
574
+ ### QuerySet Caching
575
+
576
+ ```python
577
+ from django.core.cache import cache
578
+
579
+ def get_popular_categories():
580
+ cache_key = 'popular_categories'
581
+ categories = cache.get(cache_key)
582
+
583
+ if categories is None:
584
+ categories = list(Category.objects.annotate(
585
+ product_count=Count('products')
586
+ ).filter(product_count__gt=10).order_by('-product_count')[:20])
587
+ cache.set(cache_key, categories, timeout=60 * 60) # 1 hour
588
+
589
+ return categories
590
+ ```
591
+
592
+ ## Signals
593
+
594
+ ### Signal Patterns
595
+
596
+ ```python
597
+ # apps/users/signals.py
598
+ from django.db.models.signals import post_save
599
+ from django.dispatch import receiver
600
+ from django.contrib.auth import get_user_model
601
+ from .models import Profile
602
+
603
+ User = get_user_model()
604
+
605
+ @receiver(post_save, sender=User)
606
+ def create_user_profile(sender, instance, created, **kwargs):
607
+ """Create profile when user is created."""
608
+ if created:
609
+ Profile.objects.create(user=instance)
610
+
611
+ @receiver(post_save, sender=User)
612
+ def save_user_profile(sender, instance, **kwargs):
613
+ """Save profile when user is saved."""
614
+ instance.profile.save()
615
+
616
+ # apps/users/apps.py
617
+ from django.apps import AppConfig
618
+
619
+ class UsersConfig(AppConfig):
620
+ default_auto_field = 'django.db.models.BigAutoField'
621
+ name = 'apps.users'
622
+
623
+ def ready(self):
624
+ """Import signals when app is ready."""
625
+ import apps.users.signals
626
+ ```
627
+
628
+ ## Middleware
629
+
630
+ ### Custom Middleware
631
+
632
+ ```python
633
+ # middleware/active_user_middleware.py
634
+ import time
635
+ from django.utils.deprecation import MiddlewareMixin
636
+
637
+ class ActiveUserMiddleware(MiddlewareMixin):
638
+ """Middleware to track active users."""
639
+
640
+ def process_request(self, request):
641
+ """Process incoming request."""
642
+ if request.user.is_authenticated:
643
+ # Update last active time
644
+ request.user.last_active = timezone.now()
645
+ request.user.save(update_fields=['last_active'])
646
+
647
+ class RequestLoggingMiddleware(MiddlewareMixin):
648
+ """Middleware for logging requests."""
649
+
650
+ def process_request(self, request):
651
+ """Log request start time."""
652
+ request.start_time = time.time()
653
+
654
+ def process_response(self, request, response):
655
+ """Log request duration."""
656
+ if hasattr(request, 'start_time'):
657
+ duration = time.time() - request.start_time
658
+ logger.info(f'{request.method} {request.path} - {response.status_code} - {duration:.3f}s')
659
+ return response
660
+ ```
661
+
662
+ ## Performance Optimization
663
+
664
+ ### N+1 Query Prevention
665
+
666
+ ```python
667
+ # Bad - N+1 queries
668
+ products = Product.objects.all()
669
+ for product in products:
670
+ print(product.category.name) # Separate query for each product
671
+
672
+ # Good - Single query with select_related
673
+ products = Product.objects.select_related('category').all()
674
+ for product in products:
675
+ print(product.category.name)
676
+
677
+ # Good - Prefetch for many-to-many
678
+ products = Product.objects.prefetch_related('tags').all()
679
+ for product in products:
680
+ for tag in product.tags.all():
681
+ print(tag.name)
682
+ ```
683
+
684
+ ### Database Indexing
685
+
686
+ ```python
687
+ class Product(models.Model):
688
+ name = models.CharField(max_length=200, db_index=True)
689
+ slug = models.SlugField(unique=True)
690
+ category = models.ForeignKey('Category', on_delete=models.CASCADE)
691
+ created_at = models.DateTimeField(auto_now_add=True)
692
+
693
+ class Meta:
694
+ indexes = [
695
+ models.Index(fields=['name']),
696
+ models.Index(fields=['-created_at']),
697
+ models.Index(fields=['category', 'created_at']),
698
+ ]
699
+ ```
700
+
701
+ ### Bulk Operations
702
+
703
+ ```python
704
+ # Bulk create
705
+ Product.objects.bulk_create([
706
+ Product(name=f'Product {i}', price=10.00)
707
+ for i in range(1000)
708
+ ])
709
+
710
+ # Bulk update
711
+ products = Product.objects.all()[:100]
712
+ for product in products:
713
+ product.is_active = True
714
+ Product.objects.bulk_update(products, ['is_active'])
715
+
716
+ # Bulk delete
717
+ Product.objects.filter(stock=0).delete()
718
+ ```
719
+
720
+ ## Quick Reference
721
+
722
+ | Pattern | Description |
723
+ |---------|-------------|
724
+ | Split settings | Separate dev/prod/test settings |
725
+ | Custom QuerySet | Reusable query methods |
726
+ | Service Layer | Business logic separation |
727
+ | ViewSet | REST API endpoints |
728
+ | Serializer validation | Request/response transformation |
729
+ | select_related | Foreign key optimization |
730
+ | prefetch_related | Many-to-many optimization |
731
+ | Cache first | Cache expensive operations |
732
+ | Signals | Event-driven actions |
733
+ | Middleware | Request/response processing |
734
+
735
+ Remember: Django provides many shortcuts, but for production applications, structure and organization matter more than concise code. Build for maintainability.