@rubix0270/arboris 1.0.2 → 1.0.3

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 +8 -20
  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,735 +0,0 @@
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.