@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.
- package/.agent/agents/architect.md +211 -211
- package/.agent/agents/build-error-resolver.md +114 -114
- package/.agent/agents/chief-of-staff.md +151 -151
- package/.agent/agents/code-reviewer.md +237 -237
- package/.agent/agents/cpp-build-resolver.md +90 -90
- package/.agent/agents/cpp-reviewer.md +72 -72
- package/.agent/agents/csharp-reviewer.md +101 -0
- package/.agent/agents/dart-build-resolver.md +201 -0
- package/.agent/agents/database-reviewer.md +91 -91
- package/.agent/agents/doc-updater.md +107 -107
- package/.agent/agents/docs-lookup.md +68 -68
- package/.agent/agents/e2e-runner.md +107 -107
- package/.agent/agents/flutter-reviewer.md +243 -243
- package/.agent/agents/gan-evaluator.md +209 -0
- package/.agent/agents/gan-generator.md +131 -0
- package/.agent/agents/gan-planner.md +99 -0
- package/.agent/agents/go-build-resolver.md +94 -94
- package/.agent/agents/go-reviewer.md +76 -76
- package/.agent/agents/harness-optimizer.md +35 -35
- package/.agent/agents/healthcare-reviewer.md +83 -0
- package/.agent/agents/java-build-resolver.md +153 -153
- package/.agent/agents/java-reviewer.md +92 -92
- package/.agent/agents/kotlin-build-resolver.md +118 -118
- package/.agent/agents/kotlin-reviewer.md +159 -159
- package/.agent/agents/loop-operator.md +36 -36
- package/.agent/agents/opensource-forker.md +198 -0
- package/.agent/agents/opensource-packager.md +249 -0
- package/.agent/agents/opensource-sanitizer.md +188 -0
- package/.agent/agents/performance-optimizer.md +392 -133
- package/.agent/agents/personas/athena-agent/agent.json +10 -0
- package/.agent/agents/personas/athena-agent/athena-backend-logic-architecture-profile.md +189 -0
- package/.agent/agents/personas/athena-agent/context-files/agents.md +55 -0
- package/.agent/agents/personas/athena-agent/context-files/identity.md +23 -0
- package/.agent/agents/personas/athena-agent/context-files/soul.md +51 -0
- package/.agent/agents/personas/athena-agent/context-files/user-predefined.md +15 -0
- package/.agent/agents/personas/athena-agent/user-context-files/system/bootstrap.md +37 -0
- package/.agent/agents/personas/athena-agent/user-context-files/system/user.md +45 -0
- package/.agent/agents/personas/da-vinci-agent/agent.json +10 -0
- package/.agent/agents/personas/da-vinci-agent/context-files/agents.md +55 -0
- package/.agent/agents/personas/da-vinci-agent/context-files/identity.md +23 -0
- package/.agent/agents/personas/da-vinci-agent/context-files/soul.md +51 -0
- package/.agent/agents/personas/da-vinci-agent/context-files/user-predefined.md +15 -0
- package/.agent/agents/personas/da-vinci-agent/da-vinci-frontend-ui-ux-design-profile.md +189 -0
- package/.agent/agents/personas/da-vinci-agent/user-context-files/system/bootstrap.md +37 -0
- package/.agent/agents/personas/da-vinci-agent/user-context-files/system/user.md +45 -0
- package/.agent/agents/personas/duong-tang-agent/agent.json +10 -0
- package/.agent/agents/personas/duong-tang-agent/context-files/agents.md +55 -0
- package/.agent/agents/personas/duong-tang-agent/context-files/identity.md +23 -0
- package/.agent/agents/personas/duong-tang-agent/context-files/soul.md +51 -0
- package/.agent/agents/personas/duong-tang-agent/context-files/user-predefined.md +15 -0
- package/.agent/agents/personas/duong-tang-agent/tang-monk-quality-testing-documentation-profile.md +189 -0
- package/.agent/agents/personas/duong-tang-agent/user-context-files/system/bootstrap.md +37 -0
- package/.agent/agents/personas/duong-tang-agent/user-context-files/system/user.md +45 -0
- package/.agent/agents/personas/gia-cat-luong-agent/agent.json +10 -0
- package/.agent/agents/personas/gia-cat-luong-agent/context-files/agents.md +55 -0
- package/.agent/agents/personas/gia-cat-luong-agent/context-files/identity.md +23 -0
- package/.agent/agents/personas/gia-cat-luong-agent/context-files/soul.md +51 -0
- package/.agent/agents/personas/gia-cat-luong-agent/context-files/user-predefined.md +15 -0
- package/.agent/agents/personas/gia-cat-luong-agent/kongming-research-strategy-analysis-profile.md +189 -0
- package/.agent/agents/personas/gia-cat-luong-agent/user-context-files/system/bootstrap.md +37 -0
- package/.agent/agents/personas/gia-cat-luong-agent/user-context-files/system/user.md +45 -0
- package/.agent/agents/personas/mihata-agent/agent.json +10 -0
- package/.agent/agents/personas/mihata-agent/context-files/agents.md +55 -0
- package/.agent/agents/personas/mihata-agent/context-files/identity.md +23 -0
- package/.agent/agents/personas/mihata-agent/context-files/soul.md +51 -0
- package/.agent/agents/personas/mihata-agent/context-files/user-predefined.md +15 -0
- package/.agent/agents/personas/mihata-agent/mihata-multi-agent-orchestration-profile.md +189 -0
- package/.agent/agents/personas/mihata-agent/user-context-files/system/bootstrap.md +37 -0
- package/.agent/agents/personas/mihata-agent/user-context-files/system/user.md +45 -0
- package/.agent/agents/personas/tesla-agent/agent.json +10 -0
- package/.agent/agents/personas/tesla-agent/context-files/agents.md +55 -0
- package/.agent/agents/personas/tesla-agent/context-files/identity.md +23 -0
- package/.agent/agents/personas/tesla-agent/context-files/soul.md +51 -0
- package/.agent/agents/personas/tesla-agent/context-files/user-predefined.md +15 -0
- package/.agent/agents/personas/tesla-agent/tesla-fullstack-system-optimization-profile.md +189 -0
- package/.agent/agents/personas/tesla-agent/user-context-files/system/bootstrap.md +37 -0
- package/.agent/agents/personas/tesla-agent/user-context-files/system/user.md +45 -0
- package/.agent/agents/personas/tu-ma-y-agent/agent.json +10 -0
- package/.agent/agents/personas/tu-ma-y-agent/context-files/agents.md +55 -0
- package/.agent/agents/personas/tu-ma-y-agent/context-files/identity.md +23 -0
- package/.agent/agents/personas/tu-ma-y-agent/context-files/soul.md +51 -0
- package/.agent/agents/personas/tu-ma-y-agent/context-files/user-predefined.md +15 -0
- package/.agent/agents/personas/tu-ma-y-agent/simayi-feasibility-risk-control-profile.md +189 -0
- package/.agent/agents/personas/tu-ma-y-agent/user-context-files/system/bootstrap.md +37 -0
- package/.agent/agents/personas/tu-ma-y-agent/user-context-files/system/user.md +45 -0
- package/.agent/agents/personas/venti-agent/agent.json +10 -0
- package/.agent/agents/personas/venti-agent/context-files/agents.md +55 -0
- package/.agent/agents/personas/venti-agent/context-files/identity.md +23 -0
- package/.agent/agents/personas/venti-agent/context-files/soul.md +51 -0
- package/.agent/agents/personas/venti-agent/context-files/user-predefined.md +15 -0
- package/.agent/agents/personas/venti-agent/user-context-files/system/bootstrap.md +37 -0
- package/.agent/agents/personas/venti-agent/user-context-files/system/user.md +45 -0
- package/.agent/agents/personas/venti-agent/venti-learning-communication-mentoring-profile.md +189 -0
- package/.agent/agents/planner.md +212 -212
- package/.agent/agents/python-reviewer.md +98 -98
- package/.agent/agents/pytorch-build-resolver.md +120 -120
- package/.agent/agents/refactor-cleaner.md +85 -85
- package/.agent/agents/rust-build-resolver.md +148 -148
- package/.agent/agents/rust-reviewer.md +94 -94
- package/.agent/agents/security-reviewer.md +108 -108
- package/.agent/agents/tdd-guide.md +91 -91
- package/.agent/agents/typescript-reviewer.md +112 -112
- package/.agent/contexts/dev.md +20 -0
- package/.agent/contexts/research.md +26 -0
- package/.agent/contexts/review.md +22 -0
- package/.agent/hooks/hooks.json +395 -0
- package/.agent/hooks/readme.md +222 -0
- package/.agent/mcp-configs/mcp-servers.json +181 -0
- package/.agent/rules/common/agents.md +50 -0
- package/.agent/rules/common/code-review.md +124 -0
- package/.agent/rules/common/coding-style.md +48 -0
- package/.agent/rules/common/development-workflow.md +44 -0
- package/.agent/rules/common/git-workflow.md +24 -0
- package/.agent/rules/common/hooks.md +30 -0
- package/.agent/rules/common/patterns.md +31 -0
- package/.agent/rules/common/performance.md +55 -0
- package/.agent/rules/common/security.md +29 -0
- package/.agent/rules/common/testing.md +29 -0
- package/.agent/rules/cpp/coding-style.md +44 -0
- package/.agent/rules/cpp/hooks.md +39 -0
- package/.agent/rules/cpp/patterns.md +51 -0
- package/.agent/rules/cpp/security.md +51 -0
- package/.agent/rules/cpp/testing.md +44 -0
- package/.agent/rules/csharp/coding-style.md +72 -0
- package/.agent/rules/csharp/hooks.md +25 -0
- package/.agent/rules/csharp/patterns.md +50 -0
- package/.agent/rules/csharp/security.md +58 -0
- package/.agent/rules/csharp/testing.md +46 -0
- package/.agent/rules/dart/coding-style.md +159 -0
- package/.agent/rules/dart/hooks.md +66 -0
- package/.agent/rules/dart/patterns.md +261 -0
- package/.agent/rules/dart/security.md +135 -0
- package/.agent/rules/dart/testing.md +215 -0
- package/.agent/rules/golang/coding-style.md +32 -0
- package/.agent/rules/golang/hooks.md +17 -0
- package/.agent/rules/golang/patterns.md +45 -0
- package/.agent/rules/golang/security.md +34 -0
- package/.agent/rules/golang/testing.md +31 -0
- package/.agent/rules/java/coding-style.md +114 -0
- package/.agent/rules/java/hooks.md +18 -0
- package/.agent/rules/java/patterns.md +146 -0
- package/.agent/rules/java/security.md +100 -0
- package/.agent/rules/java/testing.md +131 -0
- package/.agent/rules/kotlin/coding-style.md +86 -0
- package/.agent/rules/kotlin/hooks.md +17 -0
- package/.agent/rules/kotlin/patterns.md +146 -0
- package/.agent/rules/kotlin/security.md +82 -0
- package/.agent/rules/kotlin/testing.md +128 -0
- package/.agent/rules/perl/coding-style.md +46 -0
- package/.agent/rules/perl/hooks.md +22 -0
- package/.agent/rules/perl/patterns.md +76 -0
- package/.agent/rules/perl/security.md +69 -0
- package/.agent/rules/perl/testing.md +54 -0
- package/.agent/rules/php/coding-style.md +40 -0
- package/.agent/rules/php/hooks.md +24 -0
- package/.agent/rules/php/patterns.md +33 -0
- package/.agent/rules/php/security.md +37 -0
- package/.agent/rules/php/testing.md +39 -0
- package/.agent/rules/python/coding-style.md +42 -0
- package/.agent/rules/python/hooks.md +19 -0
- package/.agent/rules/python/patterns.md +39 -0
- package/.agent/rules/python/security.md +30 -0
- package/.agent/rules/python/testing.md +38 -0
- package/.agent/rules/readme.md +111 -0
- package/.agent/rules/rust/coding-style.md +151 -0
- package/.agent/rules/rust/hooks.md +16 -0
- package/.agent/rules/rust/patterns.md +168 -0
- package/.agent/rules/rust/security.md +141 -0
- package/.agent/rules/rust/testing.md +154 -0
- package/.agent/rules/swift/coding-style.md +47 -0
- package/.agent/rules/swift/hooks.md +20 -0
- package/.agent/rules/swift/patterns.md +66 -0
- package/.agent/rules/swift/security.md +33 -0
- package/.agent/rules/swift/testing.md +45 -0
- package/.agent/rules/typescript/coding-style.md +199 -0
- package/.agent/rules/typescript/hooks.md +22 -0
- package/.agent/rules/typescript/patterns.md +52 -0
- package/.agent/rules/typescript/security.md +28 -0
- package/.agent/rules/typescript/testing.md +18 -0
- package/.agent/rules/web/coding-style.md +96 -0
- package/.agent/rules/web/design-quality.md +63 -0
- package/.agent/rules/web/hooks.md +120 -0
- package/.agent/rules/web/patterns.md +79 -0
- package/.agent/rules/web/performance.md +64 -0
- package/.agent/rules/web/security.md +57 -0
- package/.agent/rules/web/testing.md +55 -0
- package/.agent/rules/zh/agents.md +50 -0
- package/.agent/rules/zh/code-review.md +124 -0
- package/.agent/rules/zh/coding-style.md +48 -0
- package/.agent/rules/zh/development-workflow.md +44 -0
- package/.agent/rules/zh/git-workflow.md +24 -0
- package/.agent/rules/zh/hooks.md +30 -0
- package/.agent/rules/zh/patterns.md +31 -0
- package/.agent/rules/zh/performance.md +55 -0
- package/.agent/rules/zh/readme.md +108 -0
- package/.agent/rules/zh/security.md +29 -0
- package/.agent/rules/zh/testing.md +29 -0
- package/.agent/skills/agent-eval/SKILL.md +145 -0
- package/.agent/skills/agent-harness-construction/SKILL.md +73 -0
- package/.agent/skills/agent-payment-x402/SKILL.md +178 -0
- package/.agent/skills/agentic-engineering/SKILL.md +63 -0
- package/.agent/skills/ai-first-engineering/SKILL.md +51 -0
- package/.agent/skills/ai-regression-testing/SKILL.md +385 -0
- package/.agent/skills/android-clean-architecture/SKILL.md +339 -0
- package/.agent/skills/api-design/SKILL.md +523 -0
- package/.agent/skills/architecture-decision-records/SKILL.md +179 -0
- package/.agent/skills/article-writing/SKILL.md +79 -0
- package/.agent/skills/autonomous-agent-harness/SKILL.md +267 -0
- package/.agent/skills/autonomous-loops/SKILL.md +610 -0
- package/.agent/skills/backend-patterns/SKILL.md +598 -0
- package/.agent/skills/benchmark/SKILL.md +93 -0
- package/.agent/skills/blueprint/SKILL.md +105 -0
- package/.agent/skills/brand-voice/SKILL.md +97 -0
- package/.agent/skills/brand-voice/references/voice-profile-schema.md +55 -0
- package/.agent/skills/browser-qa/SKILL.md +87 -0
- package/.agent/skills/bun-runtime/SKILL.md +84 -0
- package/.agent/skills/canary-watch/SKILL.md +99 -0
- package/.agent/skills/carrier-relationship-management/SKILL.md +212 -0
- package/.agent/skills/ck/SKILL.md +147 -0
- package/.agent/skills/ck/commands/forget.mjs +44 -0
- package/.agent/skills/ck/commands/info.mjs +24 -0
- package/.agent/skills/ck/commands/init.mjs +143 -0
- package/.agent/skills/ck/commands/list.mjs +40 -0
- package/.agent/skills/ck/commands/migrate.mjs +202 -0
- package/.agent/skills/ck/commands/resume.mjs +36 -0
- package/.agent/skills/ck/commands/save.mjs +210 -0
- package/.agent/skills/ck/commands/shared.mjs +387 -0
- package/.agent/skills/ck/hooks/session-start.mjs +224 -0
- package/.agent/skills/claude-api/SKILL.md +337 -0
- package/.agent/skills/claude-devfleet/SKILL.md +103 -0
- package/.agent/skills/click-path-audit/SKILL.md +244 -0
- package/.agent/skills/clickhouse-io/SKILL.md +439 -0
- package/.agent/skills/codebase-onboarding/SKILL.md +233 -0
- package/.agent/skills/coding-standards/SKILL.md +530 -0
- package/.agent/skills/compose-multiplatform-patterns/SKILL.md +299 -0
- package/.agent/skills/configure-ecc/SKILL.md +367 -0
- package/.agent/skills/connections-optimizer/SKILL.md +189 -0
- package/.agent/skills/content-engine/SKILL.md +131 -0
- package/.agent/skills/content-hash-cache-pattern/SKILL.md +161 -0
- package/.agent/skills/context-budget/SKILL.md +135 -0
- package/.agent/skills/continuous-agent-loop/SKILL.md +45 -0
- package/.agent/skills/continuous-learning/SKILL.md +119 -0
- package/.agent/skills/continuous-learning/config.json +18 -0
- package/.agent/skills/continuous-learning/evaluate-session.sh +69 -0
- package/.agent/skills/continuous-learning-v2/SKILL.md +365 -0
- package/.agent/skills/continuous-learning-v2/agents/observer-loop.sh +271 -0
- package/.agent/skills/continuous-learning-v2/agents/observer.md +198 -0
- package/.agent/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
- package/.agent/skills/continuous-learning-v2/agents/start-observer.sh +244 -0
- package/.agent/skills/continuous-learning-v2/config.json +8 -0
- package/.agent/skills/continuous-learning-v2/hooks/observe.sh +428 -0
- package/.agent/skills/continuous-learning-v2/scripts/detect-project.sh +228 -0
- package/.agent/skills/continuous-learning-v2/scripts/instinct-cli.py +1426 -0
- package/.agent/skills/continuous-learning-v2/scripts/test-parse-instinct.py +984 -0
- package/.agent/skills/cost-aware-llm-pipeline/SKILL.md +183 -0
- package/.agent/skills/cpp-coding-standards/SKILL.md +723 -0
- package/.agent/skills/cpp-testing/SKILL.md +324 -0
- package/.agent/skills/crosspost/SKILL.md +111 -0
- package/.agent/skills/csharp-testing/SKILL.md +321 -0
- package/.agent/skills/customer-billing-ops/SKILL.md +140 -0
- package/.agent/skills/customs-trade-compliance/SKILL.md +263 -0
- package/.agent/skills/dart-flutter-patterns/SKILL.md +563 -0
- package/.agent/skills/data-scraper-agent/SKILL.md +764 -0
- package/.agent/skills/database-migrations/SKILL.md +429 -0
- package/.agent/skills/deep-research/SKILL.md +155 -0
- package/.agent/skills/deployment-patterns/SKILL.md +427 -0
- package/.agent/skills/design-system/SKILL.md +82 -0
- package/.agent/skills/django-patterns/SKILL.md +734 -0
- package/.agent/skills/django-security/SKILL.md +593 -0
- package/.agent/skills/django-tdd/SKILL.md +729 -0
- package/.agent/skills/django-verification/SKILL.md +469 -0
- package/.agent/skills/dmux-workflows/SKILL.md +191 -0
- package/.agent/skills/docker-patterns/SKILL.md +364 -0
- package/.agent/skills/documentation-lookup/SKILL.md +90 -0
- package/.agent/skills/dotnet-patterns/SKILL.md +321 -0
- package/.agent/skills/e2e-testing/SKILL.md +326 -0
- package/.agent/skills/energy-procurement/SKILL.md +228 -0
- package/.agent/skills/enterprise-agent-ops/SKILL.md +50 -0
- package/.agent/skills/eval-harness/SKILL.md +270 -0
- package/.agent/skills/exa-search/SKILL.md +103 -0
- package/.agent/skills/fal-ai-media/SKILL.md +284 -0
- package/.agent/skills/flutter-dart-code-review/SKILL.md +435 -0
- package/.agent/skills/foundation-models-on-device/SKILL.md +243 -0
- package/.agent/skills/frontend-patterns/SKILL.md +642 -0
- package/.agent/skills/frontend-slides/SKILL.md +184 -0
- package/.agent/skills/frontend-slides/style-presets.md +330 -0
- package/.agent/skills/gan-style-harness/SKILL.md +278 -0
- package/.agent/skills/git-workflow/SKILL.md +715 -0
- package/.agent/skills/golang-patterns/SKILL.md +674 -0
- package/.agent/skills/golang-testing/SKILL.md +720 -0
- package/.agent/skills/google-workspace-ops/SKILL.md +95 -0
- package/.agent/skills/healthcare-cdss-patterns/SKILL.md +245 -0
- package/.agent/skills/healthcare-emr-patterns/SKILL.md +159 -0
- package/.agent/skills/healthcare-eval-harness/SKILL.md +207 -0
- package/.agent/skills/healthcare-phi-compliance/SKILL.md +145 -0
- package/.agent/skills/hexagonal-architecture/SKILL.md +276 -0
- package/.agent/skills/inventory-demand-planning/SKILL.md +247 -0
- package/.agent/skills/investor-materials/SKILL.md +96 -0
- package/.agent/skills/investor-outreach/SKILL.md +91 -0
- package/.agent/skills/iterative-retrieval/SKILL.md +211 -0
- package/.agent/skills/java-coding-standards/SKILL.md +147 -0
- package/.agent/skills/jira-integration/SKILL.md +293 -0
- package/.agent/skills/jpa-patterns/SKILL.md +151 -0
- package/.agent/skills/kotlin-coroutines-flows/SKILL.md +284 -0
- package/.agent/skills/kotlin-exposed-patterns/SKILL.md +719 -0
- package/.agent/skills/kotlin-ktor-patterns/SKILL.md +689 -0
- package/.agent/skills/kotlin-patterns/SKILL.md +711 -0
- package/.agent/skills/kotlin-testing/SKILL.md +824 -0
- package/.agent/skills/laravel-patterns/SKILL.md +415 -0
- package/.agent/skills/laravel-plugin-discovery/SKILL.md +229 -0
- package/.agent/skills/laravel-security/SKILL.md +285 -0
- package/.agent/skills/laravel-tdd/SKILL.md +283 -0
- package/.agent/skills/laravel-verification/SKILL.md +179 -0
- package/.agent/skills/lead-intelligence/SKILL.md +321 -0
- package/.agent/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
- package/.agent/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
- package/.agent/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
- package/.agent/skills/lead-intelligence/agents/signal-scorer.md +60 -0
- package/.agent/skills/liquid-glass-design/SKILL.md +279 -0
- package/.agent/skills/logistics-exception-management/SKILL.md +222 -0
- package/.agent/skills/manim-video/SKILL.md +89 -0
- package/.agent/skills/manim-video/assets/network-graph-scene.py +52 -0
- package/.agent/skills/market-research/SKILL.md +75 -0
- package/.agent/skills/mcp-builder/SKILL.md +173 -113
- package/.agent/skills/mcp-builder/license.txt +202 -0
- package/.agent/skills/mcp-builder/reference/evaluation.md +602 -0
- package/.agent/skills/mcp-builder/reference/mcp-best-practices.md +249 -0
- package/.agent/skills/mcp-builder/reference/node-mcp-server.md +970 -0
- package/.agent/skills/mcp-builder/reference/python-mcp-server.md +719 -0
- package/.agent/skills/mcp-builder/scripts/connections.py +151 -0
- package/.agent/skills/mcp-builder/scripts/evaluation.py +373 -0
- package/.agent/skills/mcp-builder/scripts/example-evaluation.xml +22 -0
- package/.agent/skills/mcp-builder/scripts/requirements.txt +2 -0
- package/.agent/skills/mcp-server-patterns/SKILL.md +67 -0
- package/.agent/skills/nanoclaw-repl/SKILL.md +33 -0
- package/.agent/skills/nestjs-patterns/SKILL.md +230 -0
- package/.agent/skills/nextjs-turbopack/SKILL.md +44 -0
- package/.agent/skills/nutrient-document-processing/SKILL.md +167 -0
- package/.agent/skills/nuxt4-patterns/SKILL.md +100 -0
- package/.agent/skills/openclaw-persona-forge/SKILL.md +296 -0
- package/.agent/skills/openclaw-persona-forge/gacha.py +224 -0
- package/.agent/skills/openclaw-persona-forge/gacha.sh +5 -0
- package/.agent/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
- package/.agent/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
- package/.agent/skills/openclaw-persona-forge/references/error-handling.md +53 -0
- package/.agent/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
- package/.agent/skills/openclaw-persona-forge/references/naming-system.md +39 -0
- package/.agent/skills/openclaw-persona-forge/references/output-template.md +166 -0
- package/.agent/skills/opensource-pipeline/SKILL.md +255 -0
- package/.agent/skills/perl-patterns/SKILL.md +504 -0
- package/.agent/skills/perl-security/SKILL.md +503 -0
- package/.agent/skills/perl-testing/SKILL.md +475 -0
- package/.agent/skills/plankton-code-quality/SKILL.md +236 -0
- package/.agent/skills/postgres-patterns/SKILL.md +147 -0
- package/.agent/skills/product-lens/SKILL.md +85 -0
- package/.agent/skills/production-scheduling/SKILL.md +238 -0
- package/.agent/skills/project-flow-ops/SKILL.md +111 -0
- package/.agent/skills/project-guidelines-example/SKILL.md +349 -0
- package/.agent/skills/prompt-optimizer/SKILL.md +397 -0
- package/.agent/skills/python-patterns/SKILL.md +622 -313
- package/.agent/skills/python-testing/SKILL.md +816 -0
- package/.agent/skills/pytorch-patterns/SKILL.md +396 -0
- package/.agent/skills/quality-nonconformance/SKILL.md +260 -0
- package/.agent/skills/ralphinho-rfc-pipeline/SKILL.md +67 -0
- package/.agent/skills/regex-vs-llm-structured-text/SKILL.md +220 -0
- package/.agent/skills/remotion-video-creation/SKILL.md +43 -0
- package/.agent/skills/remotion-video-creation/rules/3d.md +86 -0
- package/.agent/skills/remotion-video-creation/rules/animations.md +29 -0
- package/.agent/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
- package/.agent/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
- package/.agent/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
- package/.agent/skills/remotion-video-creation/rules/assets.md +78 -0
- package/.agent/skills/remotion-video-creation/rules/audio.md +172 -0
- package/.agent/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
- package/.agent/skills/remotion-video-creation/rules/can-decode.md +75 -0
- package/.agent/skills/remotion-video-creation/rules/charts.md +58 -0
- package/.agent/skills/remotion-video-creation/rules/compositions.md +146 -0
- package/.agent/skills/remotion-video-creation/rules/display-captions.md +126 -0
- package/.agent/skills/remotion-video-creation/rules/extract-frames.md +229 -0
- package/.agent/skills/remotion-video-creation/rules/fonts.md +152 -0
- package/.agent/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
- package/.agent/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
- package/.agent/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
- package/.agent/skills/remotion-video-creation/rules/gifs.md +138 -0
- package/.agent/skills/remotion-video-creation/rules/images.md +130 -0
- package/.agent/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
- package/.agent/skills/remotion-video-creation/rules/lottie.md +67 -0
- package/.agent/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
- package/.agent/skills/remotion-video-creation/rules/measuring-text.md +143 -0
- package/.agent/skills/remotion-video-creation/rules/sequencing.md +106 -0
- package/.agent/skills/remotion-video-creation/rules/tailwind.md +11 -0
- package/.agent/skills/remotion-video-creation/rules/text-animations.md +20 -0
- package/.agent/skills/remotion-video-creation/rules/timing.md +179 -0
- package/.agent/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
- package/.agent/skills/remotion-video-creation/rules/transitions.md +122 -0
- package/.agent/skills/remotion-video-creation/rules/trimming.md +52 -0
- package/.agent/skills/remotion-video-creation/rules/videos.md +171 -0
- package/.agent/skills/repo-scan/SKILL.md +78 -0
- package/.agent/skills/returns-reverse-logistics/SKILL.md +240 -0
- package/.agent/skills/rules-distill/SKILL.md +264 -0
- package/.agent/skills/rules-distill/scripts/scan-rules.sh +58 -0
- package/.agent/skills/rules-distill/scripts/scan-skills.sh +129 -0
- package/.agent/skills/rust-patterns/SKILL.md +499 -0
- package/.agent/skills/rust-testing/SKILL.md +500 -0
- package/.agent/skills/safety-guard/SKILL.md +75 -0
- package/.agent/skills/santa-method/SKILL.md +306 -0
- package/.agent/skills/search-first/SKILL.md +161 -0
- package/.agent/skills/security-review/SKILL.md +495 -0
- package/.agent/skills/security-review/cloud-infrastructure-security.md +361 -0
- package/.agent/skills/security-scan/SKILL.md +165 -0
- package/.agent/skills/skill-comply/SKILL.md +58 -0
- package/.agent/skills/skill-comply/fixtures/compliant-trace.jsonl +5 -0
- package/.agent/skills/skill-comply/fixtures/noncompliant-trace.jsonl +3 -0
- package/.agent/skills/skill-comply/fixtures/tdd-spec.yaml +44 -0
- package/.agent/skills/skill-comply/prompts/classifier.md +24 -0
- package/.agent/skills/skill-comply/prompts/scenario-generator.md +62 -0
- package/.agent/skills/skill-comply/prompts/spec-generator.md +42 -0
- package/.agent/skills/skill-comply/pyproject.toml +15 -0
- package/.agent/skills/skill-comply/scripts/classifier.py +85 -0
- package/.agent/skills/skill-comply/scripts/grader.py +122 -0
- package/.agent/skills/skill-comply/scripts/init.py +0 -0
- package/.agent/skills/skill-comply/scripts/parser.py +107 -0
- package/.agent/skills/skill-comply/scripts/report.py +170 -0
- package/.agent/skills/skill-comply/scripts/run.py +127 -0
- package/.agent/skills/skill-comply/scripts/runner.py +161 -0
- package/.agent/skills/skill-comply/scripts/scenario-generator.py +70 -0
- package/.agent/skills/skill-comply/scripts/spec-generator.py +72 -0
- package/.agent/skills/skill-comply/scripts/utils.py +13 -0
- package/.agent/skills/skill-comply/tests/test-grader.py +137 -0
- package/.agent/skills/skill-comply/tests/test-parser.py +90 -0
- package/.agent/skills/skill-creator/SKILL.md +485 -0
- package/.agent/skills/skill-creator/agents/analyzer.md +274 -0
- package/.agent/skills/skill-creator/agents/comparator.md +202 -0
- package/.agent/skills/skill-creator/agents/grader.md +223 -0
- package/.agent/skills/skill-creator/assets/eval-review.html +146 -0
- package/.agent/skills/skill-creator/eval-viewer/generate-review.py +471 -0
- package/.agent/skills/skill-creator/eval-viewer/viewer.html +1325 -0
- package/.agent/skills/skill-creator/license.txt +202 -0
- package/.agent/skills/skill-creator/references/schemas.md +430 -0
- package/.agent/skills/skill-creator/scripts/aggregate-benchmark.py +401 -0
- package/.agent/skills/skill-creator/scripts/generate-report.py +326 -0
- package/.agent/skills/skill-creator/scripts/improve-description.py +247 -0
- package/.agent/skills/skill-creator/scripts/init.py +0 -0
- package/.agent/skills/skill-creator/scripts/package-skill.py +136 -0
- package/.agent/skills/skill-creator/scripts/quick-validate.py +103 -0
- package/.agent/skills/skill-creator/scripts/run-eval.py +310 -0
- package/.agent/skills/skill-creator/scripts/run-loop.py +328 -0
- package/.agent/skills/skill-creator/scripts/utils.py +47 -0
- package/.agent/skills/skill-stocktake/SKILL.md +193 -0
- package/.agent/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
- package/.agent/skills/skill-stocktake/scripts/save-results.sh +56 -0
- package/.agent/skills/skill-stocktake/scripts/scan.sh +170 -0
- package/.agent/skills/social-graph-ranker/SKILL.md +154 -0
- package/.agent/skills/springboot-patterns/SKILL.md +314 -0
- package/.agent/skills/springboot-security/SKILL.md +272 -0
- package/.agent/skills/springboot-tdd/SKILL.md +158 -0
- package/.agent/skills/springboot-verification/SKILL.md +231 -0
- package/.agent/skills/strategic-compact/SKILL.md +131 -0
- package/.agent/skills/strategic-compact/suggest-compact.sh +54 -0
- package/.agent/skills/swift-actor-persistence/SKILL.md +143 -0
- package/.agent/skills/swift-concurrency-6-2/SKILL.md +216 -0
- package/.agent/skills/swift-protocol-di-testing/SKILL.md +190 -0
- package/.agent/skills/swiftui-patterns/SKILL.md +259 -0
- package/.agent/skills/tdd-workflow/SKILL.md +412 -98
- package/.agent/skills/team-builder/SKILL.md +168 -0
- package/.agent/skills/token-budget-advisor/SKILL.md +133 -0
- package/.agent/skills/ui-demo/SKILL.md +465 -0
- package/.agent/skills/ui-ux-pro-max/data/charts.csv +26 -26
- package/.agent/skills/ui-ux-pro-max/data/colors.csv +97 -97
- package/.agent/skills/ui-ux-pro-max/data/landing.csv +28 -28
- package/.agent/skills/ui-ux-pro-max/data/products.csv +96 -96
- package/.agent/skills/ui-ux-pro-max/data/stacks/flutter.csv +53 -53
- package/.agent/skills/ui-ux-pro-max/data/stacks/html-tailwind.csv +56 -56
- package/.agent/skills/ui-ux-pro-max/data/stacks/nextjs.csv +53 -53
- package/.agent/skills/ui-ux-pro-max/data/stacks/react-native.csv +52 -52
- package/.agent/skills/ui-ux-pro-max/data/stacks/react.csv +54 -54
- package/.agent/skills/ui-ux-pro-max/data/stacks/svelte.csv +54 -54
- package/.agent/skills/ui-ux-pro-max/data/stacks/swiftui.csv +51 -51
- package/.agent/skills/ui-ux-pro-max/data/stacks/vue.csv +50 -50
- package/.agent/skills/ui-ux-pro-max/data/styles.csv +68 -68
- package/.agent/skills/ui-ux-pro-max/data/ux-guidelines.csv +99 -99
- package/.agent/skills/ui-ux-pro-max/scripts/search.py +114 -114
- package/.agent/skills/verification-loop/SKILL.md +126 -0
- package/.agent/skills/video-editing/SKILL.md +310 -0
- package/.agent/skills/videodb/SKILL.md +374 -0
- package/.agent/skills/videodb/reference/api-reference.md +550 -0
- package/.agent/skills/videodb/reference/capture-reference.md +407 -0
- package/.agent/skills/videodb/reference/capture.md +101 -0
- package/.agent/skills/videodb/reference/editor.md +443 -0
- package/.agent/skills/videodb/reference/generative.md +331 -0
- package/.agent/skills/videodb/reference/rtstream-reference.md +564 -0
- package/.agent/skills/videodb/reference/rtstream.md +65 -0
- package/.agent/skills/videodb/reference/search.md +230 -0
- package/.agent/skills/videodb/reference/streaming.md +406 -0
- package/.agent/skills/videodb/reference/use-cases.md +118 -0
- package/.agent/skills/videodb/scripts/ws-listener.py +282 -0
- package/.agent/skills/visa-doc-translate/SKILL.md +117 -0
- package/.agent/skills/visa-doc-translate/readme.md +86 -0
- package/.agent/skills/workspace-surface-audit/SKILL.md +125 -0
- package/.agent/skills/x-api/SKILL.md +230 -0
- package/.agent/tasks/two-track-merge-contract.md +29 -0
- package/.agent/workflows/aside.md +164 -164
- package/.agent/workflows/build-fix.md +62 -62
- package/.agent/workflows/checkpoint.md +74 -74
- package/.agent/workflows/claw.md +23 -51
- package/.agent/workflows/clean-memory.md +34 -0
- package/.agent/workflows/code-review.md +289 -40
- package/.agent/workflows/context-budget.md +23 -29
- package/.agent/workflows/cpp-build.md +173 -173
- package/.agent/workflows/cpp-review.md +132 -132
- package/.agent/workflows/cpp-test.md +251 -251
- package/.agent/workflows/devfleet.md +23 -92
- package/.agent/workflows/docs.md +23 -31
- package/.agent/workflows/e2e.md +268 -365
- package/.agent/workflows/eval.md +23 -120
- package/.agent/workflows/evolve.md +178 -178
- package/.agent/workflows/flutter-build.md +164 -0
- package/.agent/workflows/flutter-review.md +116 -0
- package/.agent/workflows/flutter-test.md +144 -0
- package/.agent/workflows/gan-build.md +99 -0
- package/.agent/workflows/gan-design.md +35 -0
- package/.agent/workflows/go-build.md +183 -183
- package/.agent/workflows/go-review.md +148 -148
- package/.agent/workflows/go-test.md +268 -268
- package/.agent/workflows/gradle-build.md +70 -70
- package/.agent/workflows/harness-audit.md +73 -71
- package/.agent/workflows/instinct-export.md +66 -66
- package/.agent/workflows/instinct-import.md +114 -114
- package/.agent/workflows/instinct-status.md +59 -59
- package/.agent/workflows/jira.md +106 -0
- package/.agent/workflows/kotlin-build.md +174 -174
- package/.agent/workflows/kotlin-review.md +140 -140
- package/.agent/workflows/kotlin-test.md +312 -312
- package/.agent/workflows/learn-eval.md +116 -116
- package/.agent/workflows/learn.md +70 -70
- package/.agent/workflows/loop-start.md +32 -32
- package/.agent/workflows/loop-status.md +24 -24
- package/.agent/workflows/model-route.md +26 -26
- package/.agent/workflows/multi-backend.md +158 -158
- package/.agent/workflows/multi-execute.md +315 -315
- package/.agent/workflows/multi-frontend.md +158 -158
- package/.agent/workflows/multi-plan.md +268 -268
- package/.agent/workflows/multi-workflow.md +191 -191
- package/.agent/workflows/orchestrate.md +135 -231
- package/.agent/workflows/plan.md +117 -115
- package/.agent/workflows/pm2.md +272 -272
- package/.agent/workflows/projects.md +39 -39
- package/.agent/workflows/promote.md +41 -41
- package/.agent/workflows/prompt-optimize.md +23 -38
- package/.agent/workflows/prp-commit.md +112 -0
- package/.agent/workflows/prp-implement.md +385 -0
- package/.agent/workflows/prp-plan.md +502 -0
- package/.agent/workflows/prp-pr.md +184 -0
- package/.agent/workflows/prp-prd.md +447 -0
- package/.agent/workflows/prune.md +31 -31
- package/.agent/workflows/python-review.md +297 -297
- package/.agent/workflows/quality-gate.md +29 -29
- package/.agent/workflows/refactor-clean.md +80 -80
- package/.agent/workflows/resume-session.md +156 -156
- package/.agent/workflows/rules-distill.md +20 -11
- package/.agent/workflows/rust-build.md +187 -187
- package/.agent/workflows/rust-review.md +142 -142
- package/.agent/workflows/rust-test.md +308 -308
- package/.agent/workflows/santa-loop.md +175 -0
- package/.agent/workflows/save-session.md +275 -275
- package/.agent/workflows/sessions.md +333 -333
- package/.agent/workflows/setup-pm.md +80 -80
- package/.agent/workflows/skill-create.md +174 -174
- package/.agent/workflows/skill-health.md +54 -54
- package/.agent/workflows/tdd.md +231 -328
- package/.agent/workflows/test-coverage.md +69 -69
- package/.agent/workflows/update-codemaps.md +72 -72
- package/.agent/workflows/update-docs.md +84 -84
- package/.agent/workflows/verify.md +23 -59
- package/LICENSE +176 -176
- package/README.md +28 -20
- package/RELEASE.md +32 -36
- package/package.json +87 -79
- package/scripts/release-check.js +55 -55
- package/src/bin/cli.js +399 -53
- package/src/lib/installer.js +360 -114
- package/src/lib/manifests/stacks.js +122 -0
- package/src/lib/slash-commands.js +28 -0
- package/src/templates/claude/CLAUDE.en.md +42 -0
- package/src/templates/claude/CLAUDE.md +42 -0
- package/src/templates/claude/CLAUDE.vi.md +42 -0
- package/src/templates/codex/AGENTS.en.md +40 -0
- package/src/templates/codex/AGENTS.md +40 -0
- package/src/templates/codex/AGENTS.vi.md +40 -0
- package/src/templates/cursor/pilo-masterkit.mdc +20 -0
- package/src/templates/gemini/GEMINI.en.md +56 -0
- package/src/templates/gemini/GEMINI.md +56 -0
- package/src/templates/gemini/GEMINI.vi.md +56 -0
- 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.
|