@heyai-rules/pilo-masterkit 1.2.2 → 3.1.0

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