moai-adk 0.34.0__py3-none-any.whl → 1.1.0__py3-none-any.whl
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.
- moai_adk/__main__.py +136 -5
- moai_adk/astgrep/__init__.py +37 -0
- moai_adk/astgrep/analyzer.py +522 -0
- moai_adk/astgrep/models.py +124 -0
- moai_adk/astgrep/rules.py +179 -0
- moai_adk/cli/commands/analyze.py +11 -2
- moai_adk/cli/commands/doctor.py +7 -1
- moai_adk/cli/commands/init.py +321 -11
- moai_adk/cli/commands/language.py +7 -1
- moai_adk/cli/commands/rank.py +449 -0
- moai_adk/cli/commands/status.py +7 -1
- moai_adk/cli/commands/switch.py +325 -0
- moai_adk/cli/commands/update.py +296 -23
- moai_adk/cli/prompts/init_prompts.py +362 -66
- moai_adk/cli/prompts/translations/__init__.py +573 -0
- moai_adk/cli/ui/prompts.py +61 -2
- moai_adk/cli/worktree/cli.py +106 -1
- moai_adk/cli/worktree/manager.py +155 -0
- moai_adk/core/config/unified.py +244 -63
- moai_adk/core/credentials.py +264 -0
- moai_adk/core/error_recovery_system.py +22 -4
- moai_adk/core/git/conflict_detector.py +10 -1
- moai_adk/core/git/event_detector.py +16 -5
- moai_adk/core/integration/engine.py +2 -2
- moai_adk/core/integration/integration_tester.py +5 -5
- moai_adk/core/language_config_resolver.py +9 -3
- moai_adk/core/merge/analyzer.py +509 -324
- moai_adk/core/migration/alfred_to_moai_migrator.py +7 -1
- moai_adk/core/migration/backup_manager.py +54 -4
- moai_adk/core/migration/file_migrator.py +174 -2
- moai_adk/core/migration/interactive_checkbox_ui.py +42 -31
- moai_adk/core/migration/version_detector.py +123 -19
- moai_adk/core/migration/version_migrator.py +44 -9
- moai_adk/core/model_allocator.py +241 -0
- moai_adk/core/project/backup_utils.py +12 -2
- moai_adk/core/project/initializer.py +44 -87
- moai_adk/core/project/phase_executor.py +95 -33
- moai_adk/core/project/validator.py +16 -1
- moai_adk/core/quality/trust_checker.py +30 -10
- moai_adk/core/rollback_manager.py +60 -25
- moai_adk/core/template/backup.py +88 -6
- moai_adk/core/template/config.py +33 -9
- moai_adk/core/template/merger.py +34 -8
- moai_adk/core/template/processor.py +334 -11
- moai_adk/core/template_engine.py +10 -1
- moai_adk/core/template_variable_synchronizer.py +16 -2
- moai_adk/core/version_sync.py +54 -6
- moai_adk/foundation/__init__.py +1 -20
- moai_adk/foundation/testing.py +1 -1
- moai_adk/loop/__init__.py +54 -0
- moai_adk/loop/controller.py +305 -0
- moai_adk/loop/feedback.py +230 -0
- moai_adk/loop/state.py +209 -0
- moai_adk/loop/storage.py +220 -0
- moai_adk/lsp/__init__.py +70 -0
- moai_adk/lsp/client.py +320 -0
- moai_adk/lsp/models.py +261 -0
- moai_adk/lsp/protocol.py +404 -0
- moai_adk/lsp/server_manager.py +248 -0
- moai_adk/project/configuration.py +8 -1
- moai_adk/py.typed +0 -0
- moai_adk/ralph/__init__.py +37 -0
- moai_adk/ralph/engine.py +307 -0
- moai_adk/rank/__init__.py +21 -0
- moai_adk/rank/auth.py +425 -0
- moai_adk/rank/client.py +557 -0
- moai_adk/rank/config.py +147 -0
- moai_adk/rank/hook.py +1503 -0
- moai_adk/rank/py.typed +0 -0
- moai_adk/statusline/__init__.py +3 -0
- moai_adk/statusline/enhanced_output_style_detector.py +5 -5
- moai_adk/statusline/main.py +20 -1
- moai_adk/statusline/memory_collector.py +268 -0
- moai_adk/statusline/renderer.py +54 -38
- moai_adk/tag_system/__init__.py +48 -0
- moai_adk/tag_system/atomic_ops.py +117 -0
- moai_adk/tag_system/linkage.py +335 -0
- moai_adk/tag_system/parser.py +176 -0
- moai_adk/tag_system/validator.py +200 -0
- moai_adk/templates/.claude/agents/moai/builder-agent.md +19 -3
- moai_adk/templates/.claude/agents/moai/builder-command.md +62 -16
- moai_adk/templates/.claude/agents/moai/builder-plugin.md +763 -0
- moai_adk/templates/.claude/agents/moai/builder-skill.md +21 -5
- moai_adk/templates/.claude/agents/moai/expert-backend.md +103 -39
- moai_adk/templates/.claude/agents/moai/expert-debug.md +9 -3
- moai_adk/templates/.claude/agents/moai/expert-devops.md +16 -14
- moai_adk/templates/.claude/agents/moai/expert-frontend.md +45 -31
- moai_adk/templates/.claude/agents/moai/expert-performance.md +13 -9
- moai_adk/templates/.claude/agents/moai/expert-refactoring.md +228 -0
- moai_adk/templates/.claude/agents/moai/expert-security.md +19 -3
- moai_adk/templates/.claude/agents/moai/expert-testing.md +13 -9
- moai_adk/templates/.claude/agents/moai/manager-claude-code.md +8 -2
- moai_adk/templates/.claude/agents/moai/manager-docs.md +10 -5
- moai_adk/templates/.claude/agents/moai/manager-git.md +99 -27
- moai_adk/templates/.claude/agents/moai/manager-project.md +87 -7
- moai_adk/templates/.claude/agents/moai/manager-quality.md +22 -5
- moai_adk/templates/.claude/agents/moai/manager-spec.md +8 -2
- moai_adk/templates/.claude/agents/moai/manager-strategy.md +45 -14
- moai_adk/templates/.claude/agents/moai/manager-tdd.md +16 -3
- moai_adk/templates/.claude/commands/moai/0-project.md +239 -1185
- moai_adk/templates/.claude/commands/moai/1-plan.md +383 -363
- moai_adk/templates/.claude/commands/moai/2-run.md +254 -347
- moai_adk/templates/.claude/commands/moai/3-sync.md +174 -100
- moai_adk/templates/.claude/commands/moai/9-feedback.md +49 -33
- moai_adk/templates/.claude/commands/moai/alfred.md +339 -0
- moai_adk/templates/.claude/commands/moai/cancel-loop.md +163 -0
- moai_adk/templates/.claude/commands/moai/fix.md +264 -0
- moai_adk/templates/.claude/commands/moai/loop.md +363 -0
- moai_adk/templates/.claude/hooks/moai/lib/README.md +143 -0
- moai_adk/templates/.claude/hooks/moai/lib/__init__.py +37 -81
- moai_adk/templates/.claude/hooks/moai/lib/alfred_detector.py +105 -0
- moai_adk/templates/.claude/hooks/moai/lib/atomic_write.py +122 -0
- moai_adk/templates/.claude/hooks/moai/lib/checkpoint.py +4 -1
- moai_adk/templates/.claude/hooks/moai/lib/common.py +35 -5
- moai_adk/templates/.claude/hooks/moai/lib/config.py +376 -0
- moai_adk/templates/.claude/hooks/moai/lib/config_manager.py +24 -28
- moai_adk/templates/.claude/hooks/moai/lib/config_validator.py +14 -14
- moai_adk/templates/.claude/hooks/moai/lib/enhanced_output_style_detector.py +372 -0
- moai_adk/templates/.claude/hooks/moai/lib/exceptions.py +171 -0
- moai_adk/templates/.claude/hooks/moai/lib/file_utils.py +95 -0
- moai_adk/templates/.claude/hooks/moai/lib/git_collector.py +190 -0
- moai_adk/templates/.claude/hooks/moai/lib/git_operations_manager.py +15 -13
- moai_adk/templates/.claude/hooks/moai/lib/language_detector.py +298 -0
- moai_adk/templates/.claude/hooks/moai/lib/language_validator.py +125 -25
- moai_adk/templates/.claude/hooks/moai/lib/main.py +341 -0
- moai_adk/templates/.claude/hooks/moai/lib/memory_collector.py +268 -0
- moai_adk/templates/.claude/hooks/moai/lib/metrics_tracker.py +78 -0
- moai_adk/templates/.claude/hooks/moai/lib/models.py +9 -7
- moai_adk/templates/.claude/hooks/moai/lib/path_utils.py +204 -13
- moai_adk/templates/.claude/hooks/moai/lib/project.py +23 -14
- moai_adk/templates/.claude/hooks/moai/lib/renderer.py +359 -0
- moai_adk/templates/.claude/hooks/moai/lib/tag_linkage.py +333 -0
- moai_adk/templates/.claude/hooks/moai/lib/tag_parser.py +176 -0
- moai_adk/templates/.claude/hooks/moai/lib/tag_validator.py +200 -0
- moai_adk/templates/.claude/hooks/moai/lib/timeout.py +5 -5
- moai_adk/templates/.claude/hooks/moai/lib/tool_registry.py +896 -0
- moai_adk/templates/.claude/hooks/moai/lib/unified_timeout_manager.py +30 -18
- moai_adk/templates/.claude/hooks/moai/lib/update_checker.py +129 -0
- moai_adk/templates/.claude/hooks/moai/lib/version_reader.py +741 -0
- moai_adk/templates/.claude/hooks/moai/post_tool__ast_grep_scan.py +276 -0
- moai_adk/templates/.claude/hooks/moai/post_tool__code_formatter.py +255 -0
- moai_adk/templates/.claude/hooks/moai/post_tool__coverage_guard.py +325 -0
- moai_adk/templates/.claude/hooks/moai/post_tool__linter.py +315 -0
- moai_adk/templates/.claude/hooks/moai/post_tool__lsp_diagnostic.py +508 -0
- moai_adk/templates/.claude/hooks/moai/pre_commit__tag_validator.py +287 -0
- moai_adk/templates/.claude/hooks/moai/pre_tool__security_guard.py +268 -0
- moai_adk/templates/.claude/hooks/moai/pre_tool__tdd_enforcer.py +208 -0
- moai_adk/templates/.claude/hooks/moai/session_end__auto_cleanup.py +93 -61
- moai_adk/templates/.claude/hooks/moai/session_end__rank_submit.py +69 -0
- moai_adk/templates/.claude/hooks/moai/session_start__show_project_info.py +165 -70
- moai_adk/templates/.claude/hooks/moai/shared/utils/announcement_translator.py +206 -0
- moai_adk/templates/.claude/hooks/moai/stop__loop_controller.py +621 -0
- moai_adk/templates/.claude/output-styles/moai/alfred.md +758 -0
- moai_adk/templates/.claude/output-styles/moai/r2d2.md +86 -3
- moai_adk/templates/.claude/output-styles/moai/yoda.md +2 -2
- moai_adk/templates/.claude/settings.json +154 -77
- moai_adk/templates/.claude/skills/moai-docs-generation/SKILL.md +252 -198
- moai_adk/templates/.claude/skills/moai-docs-generation/examples.md +169 -323
- moai_adk/templates/.claude/skills/moai-docs-generation/modules/README.md +39 -27
- moai_adk/templates/.claude/skills/moai-docs-generation/modules/api-documentation.md +115 -125
- moai_adk/templates/.claude/skills/moai-docs-generation/modules/code-documentation.md +150 -150
- moai_adk/templates/.claude/skills/moai-docs-generation/modules/multi-format-output.md +182 -175
- moai_adk/templates/.claude/skills/moai-docs-generation/modules/user-guides.md +198 -138
- moai_adk/templates/.claude/skills/moai-docs-generation/reference.md +226 -320
- moai_adk/templates/.claude/skills/moai-domain-backend/SKILL.md +43 -222
- moai_adk/templates/.claude/skills/moai-domain-database/SKILL.md +75 -219
- moai_adk/templates/.claude/skills/moai-domain-frontend/SKILL.md +103 -463
- moai_adk/templates/.claude/skills/moai-domain-frontend/modules/component-architecture.md +723 -0
- moai_adk/templates/.claude/skills/moai-domain-frontend/modules/nextjs16-patterns.md +713 -0
- moai_adk/templates/.claude/skills/moai-domain-frontend/modules/performance-optimization.md +694 -0
- moai_adk/templates/.claude/skills/moai-domain-frontend/modules/react19-patterns.md +591 -0
- moai_adk/templates/.claude/skills/moai-domain-frontend/modules/state-management.md +680 -0
- moai_adk/templates/.claude/skills/moai-domain-frontend/modules/vue35-patterns.md +802 -0
- moai_adk/templates/.claude/skills/moai-domain-uiux/SKILL.md +118 -339
- moai_adk/templates/.claude/skills/moai-formats-data/SKILL.md +74 -377
- moai_adk/templates/.claude/skills/moai-formats-data/modules/README.md +299 -70
- moai_adk/templates/.claude/skills/moai-foundation-claude/SKILL.md +205 -182
- moai_adk/templates/.claude/skills/moai-foundation-claude/reference/advanced-agent-patterns.md +370 -0
- moai_adk/templates/.claude/skills/moai-foundation-claude/reference/claude-code-cli-reference-official.md +420 -0
- moai_adk/templates/.claude/skills/moai-foundation-claude/reference/claude-code-custom-slash-commands-official.md +32 -22
- moai_adk/templates/.claude/skills/moai-foundation-claude/reference/claude-code-devcontainers-official.md +381 -0
- moai_adk/templates/.claude/skills/moai-foundation-claude/reference/claude-code-discover-plugins-official.md +379 -0
- moai_adk/templates/.claude/skills/moai-foundation-claude/reference/claude-code-headless-official.md +378 -0
- moai_adk/templates/.claude/skills/moai-foundation-claude/reference/claude-code-hooks-official.md +110 -0
- moai_adk/templates/.claude/skills/moai-foundation-claude/reference/claude-code-plugin-marketplaces-official.md +308 -0
- moai_adk/templates/.claude/skills/moai-foundation-claude/reference/claude-code-plugins-official.md +640 -0
- moai_adk/templates/.claude/skills/moai-foundation-claude/reference/claude-code-sandboxing-official.md +282 -0
- moai_adk/templates/.claude/skills/moai-foundation-claude/reference/claude-code-skills-official.md +425 -71
- moai_adk/templates/.claude/skills/moai-foundation-claude/reference/claude-code-statusline-official.md +293 -0
- moai_adk/templates/.claude/skills/moai-foundation-claude/reference/claude-code-sub-agents-official.md +325 -143
- moai_adk/templates/.claude/skills/moai-foundation-context/SKILL.md +96 -316
- moai_adk/templates/.claude/skills/moai-foundation-core/SKILL.md +116 -294
- moai_adk/templates/.claude/skills/moai-foundation-core/modules/delegation-advanced.md +279 -0
- moai_adk/templates/.claude/skills/moai-foundation-core/modules/delegation-implementation.md +267 -0
- moai_adk/templates/.claude/skills/moai-foundation-core/modules/delegation-patterns.md +121 -650
- moai_adk/templates/.claude/skills/moai-foundation-core/modules/patterns.md +22 -0
- moai_adk/templates/.claude/skills/moai-foundation-core/modules/spec-ears-format.md +200 -0
- moai_adk/templates/.claude/skills/moai-foundation-core/modules/spec-first-tdd.md +37 -730
- moai_adk/templates/.claude/skills/moai-foundation-core/modules/spec-tdd-implementation.md +275 -0
- moai_adk/templates/.claude/skills/moai-foundation-core/modules/trust-5-framework.md +77 -819
- moai_adk/templates/.claude/skills/moai-foundation-core/modules/trust-5-implementation.md +244 -0
- moai_adk/templates/.claude/skills/moai-foundation-core/modules/trust-5-validation.md +219 -0
- moai_adk/templates/.claude/skills/moai-foundation-philosopher/SKILL.md +14 -18
- moai_adk/templates/.claude/skills/moai-foundation-quality/SKILL.md +86 -270
- moai_adk/templates/.claude/skills/moai-framework-electron/SKILL.md +288 -0
- moai_adk/templates/.claude/skills/moai-framework-electron/examples.md +2082 -0
- moai_adk/templates/.claude/skills/moai-framework-electron/reference.md +1649 -0
- moai_adk/templates/.claude/skills/moai-lang-cpp/SKILL.md +76 -582
- moai_adk/templates/.claude/skills/moai-lang-cpp/examples.md +1239 -0
- moai_adk/templates/.claude/skills/moai-lang-cpp/modules/advanced-patterns.md +401 -0
- moai_adk/templates/.claude/skills/moai-lang-cpp/reference.md +1136 -0
- moai_adk/templates/.claude/skills/moai-lang-csharp/SKILL.md +82 -436
- moai_adk/templates/.claude/skills/moai-lang-csharp/examples.md +585 -0
- moai_adk/templates/.claude/skills/moai-lang-csharp/modules/aspnet-core.md +627 -0
- moai_adk/templates/.claude/skills/moai-lang-csharp/modules/blazor-components.md +767 -0
- moai_adk/templates/.claude/skills/moai-lang-csharp/modules/cqrs-validation.md +626 -0
- moai_adk/templates/.claude/skills/moai-lang-csharp/modules/csharp12-features.md +580 -0
- moai_adk/templates/.claude/skills/moai-lang-csharp/modules/efcore-patterns.md +622 -0
- moai_adk/templates/.claude/skills/moai-lang-csharp/reference.md +403 -0
- moai_adk/templates/.claude/skills/moai-lang-elixir/SKILL.md +65 -542
- moai_adk/templates/.claude/skills/moai-lang-elixir/examples.md +1171 -0
- moai_adk/templates/.claude/skills/moai-lang-elixir/modules/advanced-patterns.md +531 -0
- moai_adk/templates/.claude/skills/moai-lang-elixir/reference.md +889 -0
- moai_adk/templates/.claude/skills/moai-lang-flutter/SKILL.md +32 -405
- moai_adk/templates/.claude/skills/moai-lang-go/SKILL.md +114 -293
- moai_adk/templates/.claude/skills/moai-lang-java/SKILL.md +83 -307
- moai_adk/templates/.claude/skills/moai-lang-javascript/SKILL.md +179 -0
- moai_adk/templates/.claude/skills/moai-lang-javascript/examples.md +973 -0
- moai_adk/templates/.claude/skills/moai-lang-javascript/reference.md +1543 -0
- moai_adk/templates/.claude/skills/moai-lang-kotlin/SKILL.md +42 -279
- moai_adk/templates/.claude/skills/moai-lang-php/SKILL.md +94 -556
- moai_adk/templates/.claude/skills/moai-lang-php/examples.md +1608 -0
- moai_adk/templates/.claude/skills/moai-lang-php/modules/advanced-patterns.md +538 -0
- moai_adk/templates/.claude/skills/moai-lang-php/reference.md +1323 -0
- moai_adk/templates/.claude/skills/moai-lang-python/SKILL.md +108 -358
- moai_adk/templates/.claude/skills/moai-lang-r/SKILL.md +84 -482
- moai_adk/templates/.claude/skills/moai-lang-r/examples.md +1154 -0
- moai_adk/templates/.claude/skills/moai-lang-r/modules/advanced-patterns.md +489 -0
- moai_adk/templates/.claude/skills/moai-lang-r/reference.md +1087 -0
- moai_adk/templates/.claude/skills/moai-lang-ruby/SKILL.md +106 -610
- moai_adk/templates/.claude/skills/moai-lang-ruby/examples.md +1106 -0
- moai_adk/templates/.claude/skills/moai-lang-ruby/modules/advanced-patterns.md +309 -0
- moai_adk/templates/.claude/skills/moai-lang-ruby/modules/testing-patterns.md +306 -0
- moai_adk/templates/.claude/skills/moai-lang-ruby/reference.md +1024 -0
- moai_adk/templates/.claude/skills/moai-lang-rust/SKILL.md +51 -265
- moai_adk/templates/.claude/skills/moai-lang-scala/SKILL.md +106 -442
- moai_adk/templates/.claude/skills/moai-lang-scala/modules/akka-actors.md +479 -0
- moai_adk/templates/.claude/skills/moai-lang-scala/modules/cats-effect.md +489 -0
- moai_adk/templates/.claude/skills/moai-lang-scala/modules/functional-programming.md +460 -0
- moai_adk/templates/.claude/skills/moai-lang-scala/modules/spark-data.md +498 -0
- moai_adk/templates/.claude/skills/moai-lang-scala/modules/zio-patterns.md +541 -0
- moai_adk/templates/.claude/skills/moai-lang-swift/SKILL.md +88 -457
- moai_adk/templates/.claude/skills/moai-lang-swift/modules/combine-reactive.md +256 -0
- moai_adk/templates/.claude/skills/moai-lang-swift/modules/concurrency.md +270 -0
- moai_adk/templates/.claude/skills/moai-lang-swift/modules/swift6-features.md +265 -0
- moai_adk/templates/.claude/skills/moai-lang-swift/modules/swiftui-patterns.md +314 -0
- moai_adk/templates/.claude/skills/moai-lang-typescript/SKILL.md +75 -283
- moai_adk/templates/.claude/skills/moai-library-mermaid/SKILL.md +97 -252
- moai_adk/templates/.claude/skills/moai-library-nextra/SKILL.md +64 -240
- moai_adk/templates/.claude/skills/moai-library-nextra/modules/advanced-patterns.md +331 -12
- moai_adk/templates/.claude/skills/moai-library-nextra/modules/configuration.md +330 -37
- moai_adk/templates/.claude/skills/moai-library-shadcn/SKILL.md +90 -287
- moai_adk/templates/.claude/skills/moai-platform-auth0/SKILL.md +200 -206
- moai_adk/templates/.claude/skills/moai-platform-auth0/examples.md +2446 -0
- moai_adk/templates/.claude/skills/moai-platform-auth0/modules/adaptive-mfa.md +233 -0
- moai_adk/templates/.claude/skills/moai-platform-auth0/modules/akamai-integration.md +214 -0
- moai_adk/templates/.claude/skills/moai-platform-auth0/modules/application-credentials.md +280 -0
- moai_adk/templates/.claude/skills/moai-platform-auth0/modules/attack-protection-log-events.md +224 -0
- moai_adk/templates/.claude/skills/moai-platform-auth0/modules/attack-protection-overview.md +140 -0
- moai_adk/templates/.claude/skills/moai-platform-auth0/modules/bot-detection.md +144 -0
- moai_adk/templates/.claude/skills/moai-platform-auth0/modules/breached-password-detection.md +187 -0
- moai_adk/templates/.claude/skills/moai-platform-auth0/modules/brute-force-protection.md +189 -0
- moai_adk/templates/.claude/skills/moai-platform-auth0/modules/certifications.md +282 -0
- moai_adk/templates/.claude/skills/moai-platform-auth0/modules/compliance-overview.md +263 -0
- moai_adk/templates/.claude/skills/moai-platform-auth0/modules/continuous-session-protection.md +307 -0
- moai_adk/templates/.claude/skills/moai-platform-auth0/modules/customize-mfa.md +177 -0
- moai_adk/templates/.claude/skills/moai-platform-auth0/modules/dpop-implementation.md +283 -0
- moai_adk/templates/.claude/skills/moai-platform-auth0/modules/fapi-implementation.md +259 -0
- moai_adk/templates/.claude/skills/moai-platform-auth0/modules/gdpr-compliance.md +313 -0
- moai_adk/templates/.claude/skills/moai-platform-auth0/modules/guardian-configuration.md +269 -0
- moai_adk/templates/.claude/skills/moai-platform-auth0/modules/highly-regulated-identity.md +272 -0
- moai_adk/templates/.claude/skills/moai-platform-auth0/modules/jwt-fundamentals.md +248 -0
- moai_adk/templates/.claude/skills/moai-platform-auth0/modules/mdl-verification.md +210 -0
- moai_adk/templates/.claude/skills/moai-platform-auth0/modules/mfa-api-management.md +278 -0
- moai_adk/templates/.claude/skills/moai-platform-auth0/modules/mfa-factors.md +226 -0
- moai_adk/templates/.claude/skills/moai-platform-auth0/modules/mfa-overview.md +174 -0
- moai_adk/templates/.claude/skills/moai-platform-auth0/modules/mtls-sender-constraining.md +316 -0
- moai_adk/templates/.claude/skills/moai-platform-auth0/modules/ropg-flow-mfa.md +216 -0
- moai_adk/templates/.claude/skills/moai-platform-auth0/modules/security-center.md +325 -0
- moai_adk/templates/.claude/skills/moai-platform-auth0/modules/security-guidance.md +277 -0
- moai_adk/templates/.claude/skills/moai-platform-auth0/modules/state-parameters.md +177 -0
- moai_adk/templates/.claude/skills/moai-platform-auth0/modules/step-up-authentication.md +251 -0
- moai_adk/templates/.claude/skills/moai-platform-auth0/modules/suspicious-ip-throttling.md +240 -0
- moai_adk/templates/.claude/skills/moai-platform-auth0/modules/tenant-access-control.md +179 -0
- moai_adk/templates/.claude/skills/moai-platform-auth0/modules/webauthn-fido.md +235 -0
- moai_adk/templates/.claude/skills/moai-platform-auth0/reference.md +224 -0
- moai_adk/templates/.claude/skills/moai-platform-clerk/SKILL.md +75 -330
- moai_adk/templates/.claude/skills/moai-platform-clerk/examples.md +1426 -0
- moai_adk/templates/.claude/skills/moai-platform-clerk/modules/advanced-patterns.md +417 -0
- moai_adk/templates/.claude/skills/moai-platform-clerk/reference.md +273 -0
- moai_adk/templates/.claude/skills/moai-platform-convex/SKILL.md +100 -340
- moai_adk/templates/.claude/skills/moai-platform-convex/examples.md +506 -0
- moai_adk/templates/.claude/skills/moai-platform-convex/modules/auth-integration.md +421 -0
- moai_adk/templates/.claude/skills/moai-platform-convex/modules/file-storage.md +474 -0
- moai_adk/templates/.claude/skills/moai-platform-convex/modules/reactive-queries.md +302 -0
- moai_adk/templates/.claude/skills/moai-platform-convex/modules/server-functions.md +452 -0
- moai_adk/templates/.claude/skills/moai-platform-convex/reference.md +385 -0
- moai_adk/templates/.claude/skills/moai-platform-firebase-auth/SKILL.md +113 -326
- moai_adk/templates/.claude/skills/moai-platform-firebase-auth/examples.md +514 -0
- moai_adk/templates/.claude/skills/moai-platform-firebase-auth/modules/custom-claims.md +374 -0
- moai_adk/templates/.claude/skills/moai-platform-firebase-auth/modules/phone-auth.md +372 -0
- moai_adk/templates/.claude/skills/moai-platform-firebase-auth/modules/social-auth.md +339 -0
- moai_adk/templates/.claude/skills/moai-platform-firebase-auth/reference.md +382 -0
- moai_adk/templates/.claude/skills/moai-platform-firestore/SKILL.md +71 -302
- moai_adk/templates/.claude/skills/moai-platform-firestore/examples.md +445 -0
- moai_adk/templates/.claude/skills/moai-platform-firestore/modules/offline-cache.md +392 -0
- moai_adk/templates/.claude/skills/moai-platform-firestore/modules/realtime-listeners.md +441 -0
- moai_adk/templates/.claude/skills/moai-platform-firestore/modules/security-rules.md +352 -0
- moai_adk/templates/.claude/skills/moai-platform-firestore/modules/transactions.md +452 -0
- moai_adk/templates/.claude/skills/moai-platform-firestore/reference.md +322 -0
- moai_adk/templates/.claude/skills/moai-platform-neon/SKILL.md +101 -412
- moai_adk/templates/.claude/skills/moai-platform-neon/examples.md +470 -0
- moai_adk/templates/.claude/skills/moai-platform-neon/modules/auto-scaling.md +349 -0
- moai_adk/templates/.claude/skills/moai-platform-neon/modules/branching-workflows.md +354 -0
- moai_adk/templates/.claude/skills/moai-platform-neon/modules/connection-pooling.md +412 -0
- moai_adk/templates/.claude/skills/moai-platform-neon/modules/pitr-backups.md +458 -0
- moai_adk/templates/.claude/skills/moai-platform-neon/reference.md +272 -0
- moai_adk/templates/.claude/skills/moai-platform-railway/SKILL.md +96 -327
- moai_adk/templates/.claude/skills/moai-platform-railway/examples.md +539 -0
- moai_adk/templates/.claude/skills/moai-platform-railway/modules/docker-deployment.md +261 -0
- moai_adk/templates/.claude/skills/moai-platform-railway/modules/multi-service.md +291 -0
- moai_adk/templates/.claude/skills/moai-platform-railway/modules/networking-domains.md +338 -0
- moai_adk/templates/.claude/skills/moai-platform-railway/modules/volumes-storage.md +353 -0
- moai_adk/templates/.claude/skills/moai-platform-railway/reference.md +374 -0
- moai_adk/templates/.claude/skills/moai-platform-supabase/SKILL.md +103 -428
- moai_adk/templates/.claude/skills/moai-platform-supabase/examples.md +502 -0
- moai_adk/templates/.claude/skills/moai-platform-supabase/modules/auth-integration.md +384 -0
- moai_adk/templates/.claude/skills/moai-platform-supabase/modules/edge-functions.md +371 -0
- moai_adk/templates/.claude/skills/moai-platform-supabase/modules/postgresql-pgvector.md +231 -0
- moai_adk/templates/.claude/skills/moai-platform-supabase/modules/realtime-presence.md +354 -0
- moai_adk/templates/.claude/skills/moai-platform-supabase/modules/row-level-security.md +286 -0
- moai_adk/templates/.claude/skills/moai-platform-supabase/modules/storage-cdn.md +319 -0
- moai_adk/templates/.claude/skills/moai-platform-supabase/modules/typescript-patterns.md +453 -0
- moai_adk/templates/.claude/skills/moai-platform-supabase/reference.md +284 -0
- moai_adk/templates/.claude/skills/moai-platform-vercel/SKILL.md +96 -446
- moai_adk/templates/.claude/skills/moai-platform-vercel/examples.md +502 -0
- moai_adk/templates/.claude/skills/moai-platform-vercel/modules/analytics-speed.md +348 -0
- moai_adk/templates/.claude/skills/moai-platform-vercel/modules/deployment-config.md +344 -0
- moai_adk/templates/.claude/skills/moai-platform-vercel/modules/edge-functions.md +222 -0
- moai_adk/templates/.claude/skills/moai-platform-vercel/modules/isr-caching.md +306 -0
- moai_adk/templates/.claude/skills/moai-platform-vercel/modules/kv-storage.md +399 -0
- moai_adk/templates/.claude/skills/moai-platform-vercel/reference.md +360 -0
- moai_adk/templates/.claude/skills/moai-tool-ast-grep/SKILL.md +193 -0
- moai_adk/templates/.claude/skills/moai-tool-ast-grep/examples.md +1099 -0
- moai_adk/templates/.claude/skills/moai-tool-ast-grep/modules/language-specific.md +307 -0
- moai_adk/templates/.claude/skills/moai-tool-ast-grep/modules/pattern-syntax.md +237 -0
- moai_adk/templates/.claude/skills/moai-tool-ast-grep/modules/refactoring-patterns.md +260 -0
- moai_adk/templates/.claude/skills/moai-tool-ast-grep/modules/security-rules.md +239 -0
- moai_adk/templates/.claude/skills/moai-tool-ast-grep/reference.md +288 -0
- moai_adk/templates/.claude/skills/moai-tool-ast-grep/rules/languages/go.yml +90 -0
- moai_adk/templates/.claude/skills/moai-tool-ast-grep/rules/languages/python.yml +101 -0
- moai_adk/templates/.claude/skills/moai-tool-ast-grep/rules/languages/typescript.yml +83 -0
- moai_adk/templates/.claude/skills/moai-tool-ast-grep/rules/quality/complexity-check.yml +94 -0
- moai_adk/templates/.claude/skills/moai-tool-ast-grep/rules/quality/deprecated-apis.yml +84 -0
- moai_adk/templates/.claude/skills/moai-tool-ast-grep/rules/security/secrets-detection.yml +89 -0
- moai_adk/templates/.claude/skills/moai-tool-ast-grep/rules/security/sql-injection.yml +45 -0
- moai_adk/templates/.claude/skills/moai-tool-ast-grep/rules/security/xss-prevention.yml +50 -0
- moai_adk/templates/.claude/skills/moai-tool-ast-grep/rules/sgconfig.yml +54 -0
- moai_adk/templates/.claude/skills/moai-workflow-jit-docs/SKILL.md +225 -423
- moai_adk/templates/.claude/skills/moai-workflow-loop/SKILL.md +197 -0
- moai_adk/templates/.claude/skills/moai-workflow-loop/examples.md +1063 -0
- moai_adk/templates/.claude/skills/moai-workflow-loop/reference.md +1414 -0
- moai_adk/templates/.claude/skills/moai-workflow-project/SKILL.md +211 -314
- moai_adk/templates/.claude/skills/moai-workflow-project/schemas/tab_schema.json +15 -43
- moai_adk/templates/.claude/skills/moai-workflow-spec/SKILL.md +119 -316
- moai_adk/templates/.claude/skills/moai-workflow-spec/modules/advanced-patterns.md +237 -0
- moai_adk/templates/.claude/skills/moai-workflow-templates/SKILL.md +96 -203
- moai_adk/templates/.claude/skills/moai-workflow-testing/SKILL.md +201 -388
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/README.md +52 -3
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/ai-debugging.md +263 -806
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/automated-code-review/context7-integration.md +286 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/automated-code-review/review-workflows.md +500 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/automated-code-review/trust5-framework/relevance-analysis.md +154 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/automated-code-review/trust5-framework/safety-analysis.md +148 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/automated-code-review/trust5-framework/scoring-algorithms.md +196 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/automated-code-review/trust5-framework/timeliness-analysis.md +168 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/automated-code-review/trust5-framework/truthfulness-analysis.md +136 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/automated-code-review/trust5-framework/usability-analysis.md +153 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/automated-code-review/trust5-framework.md +257 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/automated-code-review.md +191 -1344
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/code-review/analysis-patterns.md +340 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/code-review/core-classes.md +299 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/code-review/tool-integration.md +380 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/debugging/debugging-workflows.md +451 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/debugging/error-analysis.md +442 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/performance/optimization-patterns.md +473 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/performance/profiling-techniques.md +481 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/performance-optimization/ai-optimization.md +241 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/performance-optimization/bottleneck-detection.md +397 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/performance-optimization/optimization-plan.md +315 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/performance-optimization/profiler-core.md +277 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/performance-optimization/real-time-monitoring.md +187 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/performance-optimization.md +287 -1194
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/quality-metrics.md +415 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/refactoring/ai-workflows.md +620 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/refactoring/patterns.md +692 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/security-analysis.md +429 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/smart-refactoring.md +262 -1192
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/static-analysis.md +438 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/tdd/core-classes.md +397 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/tdd-context7/advanced-features.md +494 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/tdd-context7/red-green-refactor.md +316 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/tdd-context7/test-generation.md +471 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/tdd-context7/test-patterns.md +371 -0
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/tdd-context7.md +227 -1222
- moai_adk/templates/.claude/skills/moai-workflow-testing/modules/trust5-validation.md +428 -0
- moai_adk/templates/.claude/skills/moai-workflow-worktree/SKILL.md +228 -0
- moai_adk/templates/.claude/skills/moai-workflow-worktree/modules/integration-patterns.md +149 -0
- moai_adk/templates/.claude/skills/moai-workflow-worktree/modules/moai-adk-integration.md +245 -0
- moai_adk/templates/.claude/skills/moai-workflow-worktree/modules/parallel-advanced.md +310 -0
- moai_adk/templates/.claude/skills/moai-workflow-worktree/modules/parallel-development.md +202 -0
- moai_adk/templates/.claude/skills/moai-workflow-worktree/modules/parallel-workflows.md +302 -0
- moai_adk/templates/.claude/skills/moai-workflow-worktree/modules/registry-architecture.md +271 -0
- moai_adk/templates/.claude/skills/moai-workflow-worktree/modules/resource-optimization.md +300 -0
- moai_adk/templates/.claude/skills/moai-workflow-worktree/modules/tools-integration.md +280 -0
- moai_adk/templates/.claude/skills/moai-workflow-worktree/modules/troubleshooting.md +397 -0
- moai_adk/templates/.claude/skills/moai-workflow-worktree/modules/worktree-commands.md +296 -0
- moai_adk/templates/.claude/skills/moai-workflow-worktree/modules/worktree-management.md +217 -0
- moai_adk/templates/.git-hooks/pre-push +162 -59
- moai_adk/templates/.github/workflows/ci-universal.yml +934 -133
- moai_adk/templates/.gitignore +65 -107
- moai_adk/templates/.lsp.json +152 -0
- moai_adk/templates/.mcp.json +2 -20
- moai_adk/templates/.moai/announcements/en.json +18 -0
- moai_adk/templates/.moai/announcements/ja.json +18 -0
- moai_adk/templates/.moai/announcements/ko.json +18 -0
- moai_adk/templates/.moai/announcements/zh.json +18 -0
- moai_adk/templates/.moai/config/config.yaml +8 -2
- moai_adk/templates/.moai/config/multilingual-triggers.yaml +213 -0
- moai_adk/templates/.moai/config/sections/language.yaml +2 -2
- moai_adk/templates/.moai/config/sections/llm.yaml +41 -0
- moai_adk/templates/.moai/config/sections/pricing.yaml +30 -0
- moai_adk/templates/.moai/config/sections/project.yaml +2 -2
- moai_adk/templates/.moai/config/sections/quality.yaml +43 -5
- moai_adk/templates/.moai/config/sections/ralph.yaml +55 -0
- moai_adk/templates/.moai/config/sections/system.yaml +46 -1
- moai_adk/templates/.moai/config/sections/user.yaml +1 -1
- moai_adk/templates/.moai/config/statusline-config.yaml +2 -2
- moai_adk/templates/.moai/llm-configs/glm.json +22 -0
- moai_adk/templates/CLAUDE.ja.md +343 -0
- moai_adk/templates/CLAUDE.ko.md +343 -0
- moai_adk/templates/CLAUDE.md +200 -499
- moai_adk/templates/CLAUDE.zh.md +343 -0
- moai_adk/utils/common.py +37 -0
- moai_adk/version.py +1 -1
- moai_adk-1.1.0.dist-info/METADATA +2443 -0
- moai_adk-1.1.0.dist-info/RECORD +701 -0
- {moai_adk-0.34.0.dist-info → moai_adk-1.1.0.dist-info}/entry_points.txt +2 -0
- moai_adk-1.1.0.dist-info/licenses/LICENSE +99 -0
- moai_adk/core/config/auto_spec_config.py +0 -340
- moai_adk/core/hooks/post_tool_auto_spec_completion.py +0 -901
- moai_adk/core/spec/confidence_scoring.py +0 -680
- moai_adk/core/spec/ears_template_engine.py +0 -1247
- moai_adk/core/spec/quality_validator.py +0 -687
- moai_adk/templates/.claude/agents/moai/ai-nano-banana.md +0 -670
- moai_adk/templates/.claude/agents/moai/expert-database.md +0 -777
- moai_adk/templates/.claude/agents/moai/expert-uiux.md +0 -1041
- moai_adk/templates/.claude/agents/moai/mcp-context7.md +0 -458
- moai_adk/templates/.claude/agents/moai/mcp-figma.md +0 -1607
- moai_adk/templates/.claude/agents/moai/mcp-notion.md +0 -789
- moai_adk/templates/.claude/agents/moai/mcp-playwright.md +0 -469
- moai_adk/templates/.claude/agents/moai/mcp-sequential-thinking.md +0 -1032
- moai_adk/templates/.claude/skills/moai-ai-nano-banana/SKILL.md +0 -438
- moai_adk/templates/.claude/skills/moai-ai-nano-banana/examples.md +0 -431
- moai_adk/templates/.claude/skills/moai-domain-uiux/modules/design-system-tokens.md +0 -405
- moai_adk/templates/.claude/skills/moai-library-nextra/advanced-patterns.md +0 -336
- moai_adk/templates/.claude/skills/moai-mcp-figma/SKILL.md +0 -402
- moai_adk/templates/.claude/skills/moai-mcp-figma/advanced-patterns.md +0 -607
- moai_adk/templates/.claude/skills/moai-mcp-notion/SKILL.md +0 -300
- moai_adk/templates/.claude/skills/moai-mcp-notion/advanced-patterns.md +0 -537
- moai_adk/templates/.claude/skills/moai-workflow-project/__init__.py +0 -520
- moai_adk/templates/.claude/skills/moai-workflow-project/complete_workflow_demo_fixed.py +0 -574
- moai_adk/templates/.claude/skills/moai-workflow-project/examples/complete_project_setup.py +0 -317
- moai_adk/templates/.claude/skills/moai-workflow-project/examples/complete_workflow_demo.py +0 -663
- moai_adk/templates/.claude/skills/moai-workflow-project/examples/config-migration-example.json +0 -190
- moai_adk/templates/.claude/skills/moai-workflow-project/examples/question-examples.json +0 -175
- moai_adk/templates/.claude/skills/moai-workflow-project/examples/quick_start.py +0 -196
- moai_adk/templates/.claude/skills/moai-workflow-project/modules/__init__.py +0 -17
- moai_adk/templates/.claude/skills/moai-workflow-project/modules/advanced-patterns.md +0 -158
- moai_adk/templates/.claude/skills/moai-workflow-project/modules/ask_user_integration.py +0 -340
- moai_adk/templates/.claude/skills/moai-workflow-project/modules/batch_questions.py +0 -713
- moai_adk/templates/.claude/skills/moai-workflow-project/modules/config_manager.py +0 -538
- moai_adk/templates/.claude/skills/moai-workflow-project/modules/documentation_manager.py +0 -1336
- moai_adk/templates/.claude/skills/moai-workflow-project/modules/language_initializer.py +0 -730
- moai_adk/templates/.claude/skills/moai-workflow-project/modules/migration_manager.py +0 -608
- moai_adk/templates/.claude/skills/moai-workflow-project/modules/template_optimizer.py +0 -1005
- moai_adk/templates/.claude/skills/moai-workflow-project/test_integration_simple.py +0 -436
- moai_adk/templates/.claude/skills/moai-worktree/SKILL.md +0 -411
- moai_adk/templates/.claude/skills/moai-worktree/modules/integration-patterns.md +0 -982
- moai_adk/templates/.claude/skills/moai-worktree/modules/parallel-development.md +0 -778
- moai_adk/templates/.claude/skills/moai-worktree/modules/worktree-commands.md +0 -646
- moai_adk/templates/.claude/skills/moai-worktree/modules/worktree-management.md +0 -782
- moai_adk/templates/.moai/config/questions/_schema.yaml +0 -151
- moai_adk/templates/.moai/config/questions/tab0-init.yaml +0 -251
- moai_adk/templates/.moai/config/questions/tab1-user.yaml +0 -108
- moai_adk/templates/.moai/config/questions/tab2-project.yaml +0 -81
- moai_adk/templates/.moai/config/questions/tab3-git.yaml +0 -634
- moai_adk/templates/.moai/config/questions/tab4-quality.yaml +0 -170
- moai_adk/templates/.moai/config/questions/tab5-system.yaml +0 -87
- moai_adk/templates/.moai/scripts/setup-glm.py +0 -136
- moai_adk-0.34.0.dist-info/METADATA +0 -2999
- moai_adk-0.34.0.dist-info/RECORD +0 -463
- moai_adk-0.34.0.dist-info/licenses/LICENSE +0 -21
- /moai_adk/foundation/{git.py → git/__init__.py} +0 -0
- /moai_adk/templates/.claude/skills/moai-library-mermaid/{advanced-patterns.md → modules/advanced-patterns.md} +0 -0
- /moai_adk/templates/.claude/skills/moai-library-mermaid/{optimization.md → modules/optimization.md} +0 -0
- /moai_adk/templates/.claude/skills/moai-library-nextra/{optimization.md → modules/optimization.md} +0 -0
- /moai_adk/templates/.claude/skills/moai-workflow-jit-docs/{advanced-patterns.md → modules/advanced-patterns.md} +0 -0
- /moai_adk/templates/.claude/skills/moai-workflow-jit-docs/{optimization.md → modules/optimization.md} +0 -0
- /moai_adk/templates/.claude/skills/moai-workflow-testing/{advanced-patterns.md → modules/advanced-patterns.md} +0 -0
- /moai_adk/templates/.claude/skills/moai-workflow-testing/{optimization.md → modules/optimization.md} +0 -0
- /moai_adk/templates/.claude/skills/{moai-worktree → moai-workflow-worktree}/examples.md +0 -0
- /moai_adk/templates/.claude/skills/{moai-worktree → moai-workflow-worktree}/reference.md +0 -0
- {moai_adk-0.34.0.dist-info → moai_adk-1.1.0.dist-info}/WHEEL +0 -0
|
@@ -1,71 +1,54 @@
|
|
|
1
1
|
---
|
|
2
|
-
name: moai-lang-python
|
|
3
|
-
description: Python 3.13+ development specialist covering FastAPI, Django, async patterns, data science, testing with pytest, and modern Python features. Use when developing Python APIs, web applications, data pipelines, or writing tests.
|
|
4
|
-
version: 1.
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
2
|
+
name: "moai-lang-python"
|
|
3
|
+
description: "Python 3.13+ development specialist covering FastAPI, Django, async patterns, data science, testing with pytest, and modern Python features. Use when developing Python APIs, web applications, data pipelines, or writing tests."
|
|
4
|
+
version: 1.1.0
|
|
5
|
+
category: "language"
|
|
6
|
+
modularized: false
|
|
7
|
+
user-invocable: false
|
|
8
|
+
tags:
|
|
9
|
+
["language", "python", "fastapi", "django", "pytest", "async", "data-science"]
|
|
10
|
+
updated: 2026-01-11
|
|
11
|
+
status: "active"
|
|
12
|
+
allowed-tools:
|
|
13
|
+
- Read
|
|
14
|
+
- Grep
|
|
15
|
+
- Glob
|
|
16
|
+
- Bash
|
|
17
|
+
- mcp__context7__resolve-library-id
|
|
18
|
+
- mcp__context7__get-library-docs
|
|
8
19
|
---
|
|
9
20
|
|
|
10
21
|
## Quick Reference (30 seconds)
|
|
11
22
|
|
|
12
23
|
Python 3.13+ Development Specialist - FastAPI, Django, async patterns, pytest, and modern Python features.
|
|
13
24
|
|
|
14
|
-
Auto-Triggers:
|
|
25
|
+
Auto-Triggers: Python files with .py extension, pyproject.toml, requirements.txt, pytest.ini, FastAPI or Django discussions
|
|
15
26
|
|
|
16
27
|
Core Capabilities:
|
|
17
|
-
|
|
18
|
-
-
|
|
28
|
+
|
|
29
|
+
- Python 3.13 Features: JIT compiler via PEP 744, GIL-free mode via PEP 703, pattern matching with match and case statements
|
|
30
|
+
- Web Frameworks: FastAPI 0.115 and later, Django 5.2 LTS
|
|
19
31
|
- Data Validation: Pydantic v2.9 with model_validate patterns
|
|
20
32
|
- ORM: SQLAlchemy 2.0 async patterns
|
|
21
|
-
- Testing: pytest with fixtures, async testing, parametrize
|
|
33
|
+
- Testing: pytest with fixtures, async testing, parametrize decorators
|
|
22
34
|
- Package Management: poetry, uv, pip with pyproject.toml
|
|
23
|
-
- Type Hints: Protocol, TypeVar, ParamSpec, modern typing patterns
|
|
24
|
-
- Async: asyncio, async generators, task groups
|
|
25
|
-
- Data Science: numpy, pandas, polars basics
|
|
35
|
+
- Type Hints: Protocol, TypeVar, ParamSpec, and modern typing patterns
|
|
36
|
+
- Async: asyncio, async generators, and task groups
|
|
37
|
+
- Data Science: numpy, pandas, and polars basics
|
|
26
38
|
|
|
27
39
|
### Quick Patterns
|
|
28
40
|
|
|
29
|
-
FastAPI Endpoint:
|
|
30
|
-
```python
|
|
31
|
-
from fastapi import FastAPI, Depends
|
|
32
|
-
from pydantic import BaseModel
|
|
33
|
-
|
|
34
|
-
app = FastAPI()
|
|
35
|
-
|
|
36
|
-
class UserCreate(BaseModel):
|
|
37
|
-
name: str
|
|
38
|
-
email: str
|
|
39
|
-
|
|
40
|
-
@app.post("/users/")
|
|
41
|
-
async def create_user(user: UserCreate) -> User:
|
|
42
|
-
return await UserService.create(user)
|
|
43
|
-
```
|
|
44
|
-
|
|
45
|
-
Pydantic v2.9 Validation:
|
|
46
|
-
```python
|
|
47
|
-
from pydantic import BaseModel, ConfigDict
|
|
41
|
+
FastAPI Endpoint Pattern:
|
|
48
42
|
|
|
49
|
-
class User
|
|
50
|
-
model_config = ConfigDict(from_attributes=True, str_strip_whitespace=True)
|
|
43
|
+
Import FastAPI and Depends from fastapi, and BaseModel from pydantic. Create a FastAPI application instance. Define a UserCreate model class inheriting from BaseModel with name and email string fields. Create an async post endpoint at the users path that accepts a UserCreate parameter and returns a User by calling UserService.create with await.
|
|
51
44
|
|
|
52
|
-
|
|
53
|
-
name: str
|
|
54
|
-
email: str
|
|
45
|
+
Pydantic v2.9 Validation Pattern:
|
|
55
46
|
|
|
56
|
-
|
|
57
|
-
user = User.model_validate_json(json_data) # from JSON
|
|
58
|
-
```
|
|
47
|
+
Import BaseModel and ConfigDict from pydantic. Define a User class inheriting from BaseModel. Set model_config using ConfigDict with from_attributes set to True and str_strip_whitespace set to True. Add id as integer, name as string, and email as string fields. Use model_validate to create from ORM objects and model_validate_json to create from JSON data.
|
|
59
48
|
|
|
60
|
-
pytest Async Test:
|
|
61
|
-
```python
|
|
62
|
-
import pytest
|
|
49
|
+
pytest Async Test Pattern:
|
|
63
50
|
|
|
64
|
-
|
|
65
|
-
async def test_create_user(async_client):
|
|
66
|
-
response = await async_client.post("/users/", json={"name": "Test"})
|
|
67
|
-
assert response.status_code == 201
|
|
68
|
-
```
|
|
51
|
+
Import pytest and mark the test function with pytest.mark.asyncio decorator. Create an async test function that takes async_client as a fixture parameter. Send a post request to the users endpoint with a JSON body containing a name field. Assert that the response status_code equals 201.
|
|
69
52
|
|
|
70
53
|
---
|
|
71
54
|
|
|
@@ -73,378 +56,152 @@ async def test_create_user(async_client):
|
|
|
73
56
|
|
|
74
57
|
### Python 3.13 New Features
|
|
75
58
|
|
|
76
|
-
JIT Compiler
|
|
77
|
-
|
|
78
|
-
-
|
|
79
|
-
-
|
|
59
|
+
JIT Compiler via PEP 744:
|
|
60
|
+
|
|
61
|
+
- Experimental feature disabled by default
|
|
62
|
+
- Enable using the PYTHON_JIT environment variable set to 1
|
|
63
|
+
- Build option available as enable-experimental-jit flag
|
|
80
64
|
- Provides performance improvements for CPU-bound code
|
|
81
|
-
-
|
|
65
|
+
- Uses copy-and-patch JIT that translates specialized bytecode to machine code
|
|
66
|
+
|
|
67
|
+
GIL-Free Mode via PEP 703:
|
|
82
68
|
|
|
83
|
-
|
|
84
|
-
- Experimental free-threaded build (python3.13t)
|
|
69
|
+
- Experimental free-threaded build available as python3.13t
|
|
85
70
|
- Allows true parallel thread execution
|
|
86
|
-
- Available in official Windows
|
|
87
|
-
- Best for
|
|
88
|
-
- Not recommended for production yet
|
|
89
|
-
|
|
90
|
-
Pattern Matching
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
match response:
|
|
94
|
-
case {"status": "ok", "data": data}:
|
|
95
|
-
return f"Success: {data}"
|
|
96
|
-
case {"status": "error", "message": msg}:
|
|
97
|
-
return f"Error: {msg}"
|
|
98
|
-
case {"status": status} if status in ("pending", "processing"):
|
|
99
|
-
return "In progress..."
|
|
100
|
-
case _:
|
|
101
|
-
return "Unknown response"
|
|
102
|
-
```
|
|
71
|
+
- Available in official Windows and macOS installers
|
|
72
|
+
- Best suited for CPU-intensive multi-threaded applications
|
|
73
|
+
- Not recommended for production use yet
|
|
74
|
+
|
|
75
|
+
Pattern Matching with match and case:
|
|
76
|
+
|
|
77
|
+
Create a process_response function that takes a response dictionary and returns a string. Use match statement on response. For case with status ok and data field, return success message with the data. For case with status error and message field, return error message. For case with status matching pending or processing using a guard condition, return in progress message. For default case using underscore, return unknown response.
|
|
103
78
|
|
|
104
79
|
### FastAPI 0.115+ Patterns
|
|
105
80
|
|
|
106
81
|
Async Dependency Injection:
|
|
107
|
-
```python
|
|
108
|
-
from fastapi import FastAPI, Depends
|
|
109
|
-
from sqlalchemy.ext.asyncio import AsyncSession
|
|
110
|
-
from contextlib import asynccontextmanager
|
|
111
|
-
|
|
112
|
-
@asynccontextmanager
|
|
113
|
-
async def lifespan(app: FastAPI):
|
|
114
|
-
# Startup
|
|
115
|
-
await init_db()
|
|
116
|
-
yield
|
|
117
|
-
# Shutdown
|
|
118
|
-
await cleanup()
|
|
119
|
-
|
|
120
|
-
app = FastAPI(lifespan=lifespan)
|
|
121
|
-
|
|
122
|
-
async def get_db() -> AsyncGenerator[AsyncSession, None]:
|
|
123
|
-
async with async_session() as session:
|
|
124
|
-
yield session
|
|
125
|
-
|
|
126
|
-
@app.get("/users/{user_id}")
|
|
127
|
-
async def get_user(
|
|
128
|
-
user_id: int,
|
|
129
|
-
db: AsyncSession = Depends(get_db)
|
|
130
|
-
) -> UserResponse:
|
|
131
|
-
user = await get_user_by_id(db, user_id)
|
|
132
|
-
return UserResponse.model_validate(user)
|
|
133
|
-
```
|
|
134
82
|
|
|
135
|
-
|
|
136
|
-
```python
|
|
137
|
-
from fastapi import Depends
|
|
83
|
+
Import FastAPI, Depends from fastapi, AsyncSession from sqlalchemy.ext.asyncio, and asynccontextmanager from contextlib. Create a lifespan async context manager decorated with asynccontextmanager that takes the FastAPI app. In the lifespan, call await init_db for startup, yield, then call await cleanup for shutdown. Create the FastAPI app with the lifespan parameter. Define an async get_db function returning AsyncGenerator of AsyncSession that uses async with on async_session and yields the session. Create a get endpoint for users with user_id path parameter, using Depends with get_db to inject the database session. Call await get_user_by_id and return UserResponse.model_validate with the user.
|
|
138
84
|
|
|
139
|
-
|
|
140
|
-
def __init__(self, page: int = 1, size: int = 20):
|
|
141
|
-
self.page = max(1, page)
|
|
142
|
-
self.size = min(100, max(1, size))
|
|
143
|
-
self.offset = (self.page - 1) * self.size
|
|
85
|
+
Class-Based Dependencies:
|
|
144
86
|
|
|
145
|
-
|
|
146
|
-
async def list_items(pagination: Paginator = Depends()) -> list[Item]:
|
|
147
|
-
return await Item.get_page(pagination.offset, pagination.size)
|
|
148
|
-
```
|
|
87
|
+
Create a Paginator class with an init method accepting page defaulting to 1 and size defaulting to 20. Set self.page to max of 1 and page, self.size to min of 100 and max of 1 and size, and self.offset to page minus 1 multiplied by size. Create a list_items endpoint using Depends on Paginator to inject pagination and return items using get_page with offset and size.
|
|
149
88
|
|
|
150
89
|
### Django 5.2 LTS Features
|
|
151
90
|
|
|
152
91
|
Composite Primary Keys:
|
|
153
|
-
```python
|
|
154
|
-
from django.db import models
|
|
155
|
-
|
|
156
|
-
class OrderItem(models.Model):
|
|
157
|
-
order = models.ForeignKey(Order, on_delete=models.CASCADE)
|
|
158
|
-
product = models.ForeignKey(Product, on_delete=models.CASCADE)
|
|
159
|
-
quantity = models.IntegerField()
|
|
160
92
|
|
|
161
|
-
|
|
162
|
-
pk = models.CompositePrimaryKey("order", "product")
|
|
163
|
-
```
|
|
93
|
+
Create an OrderItem model with ForeignKey to Order with CASCADE deletion, ForeignKey to Product with CASCADE deletion, and an IntegerField for quantity. In the Meta class, set pk to models.CompositePrimaryKey with order and product fields.
|
|
164
94
|
|
|
165
95
|
URL Reverse with Query Parameters:
|
|
166
|
-
```python
|
|
167
|
-
from django.urls import reverse
|
|
168
96
|
|
|
169
|
-
|
|
170
|
-
# /search/?q=django&page=1#results
|
|
171
|
-
```
|
|
97
|
+
Import reverse from django.urls. Call reverse with the search view name, query dictionary containing q set to django and page set to 1, and fragment set to results. The result is the search path with query string and fragment.
|
|
172
98
|
|
|
173
99
|
Automatic Model Imports in Shell:
|
|
174
|
-
|
|
175
|
-
python manage.py shell
|
|
176
|
-
# Models from all installed apps are automatically imported
|
|
177
|
-
```
|
|
100
|
+
|
|
101
|
+
Run python manage.py shell and models from all installed apps are automatically imported without explicit import statements.
|
|
178
102
|
|
|
179
103
|
### Pydantic v2.9 Deep Patterns
|
|
180
104
|
|
|
181
105
|
Reusable Validators with Annotated:
|
|
182
|
-
```python
|
|
183
|
-
from typing import Annotated
|
|
184
|
-
from pydantic import AfterValidator, BaseModel
|
|
185
|
-
|
|
186
|
-
def validate_positive(v: int) -> int:
|
|
187
|
-
if v <= 0:
|
|
188
|
-
raise ValueError("Must be positive")
|
|
189
|
-
return v
|
|
190
106
|
|
|
191
|
-
PositiveInt
|
|
192
|
-
|
|
193
|
-
class Product(BaseModel):
|
|
194
|
-
price: PositiveInt
|
|
195
|
-
quantity: PositiveInt
|
|
196
|
-
```
|
|
107
|
+
Import Annotated from typing and AfterValidator and BaseModel from pydantic. Define a validate_positive function that takes an integer v and returns an integer. If v is less than or equal to 0, raise ValueError with must be positive message. Otherwise return v. Create PositiveInt as Annotated with int and AfterValidator using validate_positive. Use PositiveInt in model fields for price and quantity.
|
|
197
108
|
|
|
198
109
|
Model Validator for Cross-Field Validation:
|
|
199
|
-
```python
|
|
200
|
-
from pydantic import BaseModel, model_validator
|
|
201
|
-
from typing import Self
|
|
202
|
-
|
|
203
|
-
class DateRange(BaseModel):
|
|
204
|
-
start_date: date
|
|
205
|
-
end_date: date
|
|
206
110
|
|
|
207
|
-
|
|
208
|
-
def validate_dates(self) -> Self:
|
|
209
|
-
if self.end_date < self.start_date:
|
|
210
|
-
raise ValueError("end_date must be after start_date")
|
|
211
|
-
return self
|
|
212
|
-
```
|
|
111
|
+
Import BaseModel and model_validator from pydantic, and Self from typing. Create a DateRange model with start_date and end_date as date fields. Add a model_validator decorator with mode set to after. In the validate_dates method returning Self, check if end_date is before start_date and raise ValueError if so, otherwise return self.
|
|
213
112
|
|
|
214
113
|
ConfigDict Best Practices:
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
class BaseSchema(BaseModel):
|
|
219
|
-
model_config = ConfigDict(
|
|
220
|
-
from_attributes=True, # ORM object support
|
|
221
|
-
populate_by_name=True, # Allow aliases
|
|
222
|
-
extra="forbid", # Fail on unknown fields
|
|
223
|
-
str_strip_whitespace=True, # Clean strings
|
|
224
|
-
)
|
|
225
|
-
```
|
|
114
|
+
|
|
115
|
+
Create a BaseSchema model with model_config set to ConfigDict. Set from_attributes to True for ORM object support, populate_by_name to True to allow aliases, extra to forbid to fail on unknown fields, and str_strip_whitespace to True to clean strings.
|
|
226
116
|
|
|
227
117
|
### SQLAlchemy 2.0 Async Patterns
|
|
228
118
|
|
|
229
119
|
Engine and Session Setup:
|
|
230
|
-
|
|
231
|
-
from sqlalchemy.ext.asyncio
|
|
232
|
-
create_async_engine,
|
|
233
|
-
async_sessionmaker,
|
|
234
|
-
AsyncSession,
|
|
235
|
-
)
|
|
236
|
-
|
|
237
|
-
engine = create_async_engine(
|
|
238
|
-
"postgresql+asyncpg://user:pass@localhost/db",
|
|
239
|
-
pool_pre_ping=True,
|
|
240
|
-
echo=True,
|
|
241
|
-
)
|
|
242
|
-
|
|
243
|
-
async_session = async_sessionmaker(
|
|
244
|
-
engine,
|
|
245
|
-
class_=AsyncSession,
|
|
246
|
-
expire_on_commit=False, # Prevent detached instance errors
|
|
247
|
-
)
|
|
248
|
-
```
|
|
120
|
+
|
|
121
|
+
Import create_async_engine, async_sessionmaker, and AsyncSession from sqlalchemy.ext.asyncio. Create engine using create_async_engine with the postgresql+asyncpg connection string, pool_pre_ping set to True, and echo set to True. Create async_session using async_sessionmaker with the engine, class_ set to AsyncSession, and expire_on_commit set to False to prevent detached instance errors.
|
|
249
122
|
|
|
250
123
|
Repository Pattern:
|
|
251
|
-
|
|
252
|
-
from
|
|
253
|
-
from sqlalchemy.ext.asyncio import AsyncSession
|
|
254
|
-
|
|
255
|
-
class UserRepository:
|
|
256
|
-
def __init__(self, session: AsyncSession):
|
|
257
|
-
self.session = session
|
|
258
|
-
|
|
259
|
-
async def get_by_id(self, user_id: int) -> User | None:
|
|
260
|
-
result = await self.session.execute(
|
|
261
|
-
select(User).where(User.id == user_id)
|
|
262
|
-
)
|
|
263
|
-
return result.scalar_one_or_none()
|
|
264
|
-
|
|
265
|
-
async def create(self, user: UserCreate) -> User:
|
|
266
|
-
db_user = User(**user.model_dump())
|
|
267
|
-
self.session.add(db_user)
|
|
268
|
-
await self.session.commit()
|
|
269
|
-
await self.session.refresh(db_user)
|
|
270
|
-
return db_user
|
|
271
|
-
```
|
|
124
|
+
|
|
125
|
+
Create a UserRepository class with an init method taking an AsyncSession. Define an async get_by_id method that executes a select query with a where clause for user_id, returning scalar_one_or_none result. Define an async create method that creates a User from UserCreate model_dump, adds to session, commits, refreshes, and returns the user.
|
|
272
126
|
|
|
273
127
|
Streaming Large Results:
|
|
274
|
-
|
|
275
|
-
async
|
|
276
|
-
result = await db.stream(select(User))
|
|
277
|
-
async for user in result.scalars():
|
|
278
|
-
yield user
|
|
279
|
-
```
|
|
128
|
+
|
|
129
|
+
Create an async stream_users function that takes an AsyncSession. Call await db.stream with the select User query. Use async for to iterate over result.scalars and yield each user.
|
|
280
130
|
|
|
281
131
|
### pytest Advanced Patterns
|
|
282
132
|
|
|
283
133
|
Async Fixtures with pytest-asyncio:
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
import pytest_asyncio
|
|
287
|
-
from httpx import AsyncClient
|
|
288
|
-
|
|
289
|
-
@pytest_asyncio.fixture
|
|
290
|
-
async def async_client(app) -> AsyncGenerator[AsyncClient, None]:
|
|
291
|
-
async with AsyncClient(app=app, base_url="http://test") as client:
|
|
292
|
-
yield client
|
|
293
|
-
|
|
294
|
-
@pytest_asyncio.fixture
|
|
295
|
-
async def db_session() -> AsyncGenerator[AsyncSession, None]:
|
|
296
|
-
async with async_session() as session:
|
|
297
|
-
async with session.begin():
|
|
298
|
-
yield session
|
|
299
|
-
await session.rollback()
|
|
300
|
-
```
|
|
134
|
+
|
|
135
|
+
Import pytest, pytest_asyncio, and AsyncClient from httpx. Decorate fixtures with pytest_asyncio.fixture. Create an async_client fixture that uses async with on AsyncClient with app and base_url, yielding the client. Create a db_session fixture that uses async with on async_session and session.begin, yielding session and calling await session.rollback.
|
|
301
136
|
|
|
302
137
|
Parametrized Tests:
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
"input_data,expected_status",
|
|
306
|
-
[
|
|
307
|
-
({"name": "Valid"}, 201),
|
|
308
|
-
({"name": ""}, 422),
|
|
309
|
-
({}, 422),
|
|
310
|
-
],
|
|
311
|
-
ids=["valid", "empty_name", "missing_name"],
|
|
312
|
-
)
|
|
313
|
-
async def test_create_user(async_client, input_data, expected_status):
|
|
314
|
-
response = await async_client.post("/users/", json=input_data)
|
|
315
|
-
assert response.status_code == expected_status
|
|
316
|
-
```
|
|
138
|
+
|
|
139
|
+
Use pytest.mark.parametrize decorator with input_data and expected_status parameter names. Provide test cases as tuples with dictionaries and expected status codes. Add ids for valid, empty_name, and missing_name cases. The test function takes async_client, input_data, and expected_status, posts to users endpoint, and asserts status_code matches expected.
|
|
317
140
|
|
|
318
141
|
Fixture Factories:
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
def user_factory():
|
|
322
|
-
async def _create_user(db: AsyncSession, **kwargs) -> User:
|
|
323
|
-
defaults = {"name": "Test User", "email": "test@example.com"}
|
|
324
|
-
user = User(**(defaults | kwargs))
|
|
325
|
-
db.add(user)
|
|
326
|
-
await db.commit()
|
|
327
|
-
return user
|
|
328
|
-
return _create_user
|
|
329
|
-
```
|
|
142
|
+
|
|
143
|
+
Create a user_factory fixture that returns an async function. The inner function takes db as AsyncSession and keyword arguments. Set defaults dictionary with name and email. Create User with defaults merged with kwargs using the pipe operator, add to db, commit, and return user.
|
|
330
144
|
|
|
331
145
|
### Type Hints Modern Patterns
|
|
332
146
|
|
|
333
147
|
Protocol for Structural Typing:
|
|
334
|
-
```python
|
|
335
|
-
from typing import Protocol, runtime_checkable
|
|
336
148
|
|
|
337
|
-
|
|
338
|
-
class Repository(Protocol[T]):
|
|
339
|
-
async def get(self, id: int) -> T | None: ...
|
|
340
|
-
async def create(self, data: dict) -> T: ...
|
|
341
|
-
async def delete(self, id: int) -> bool: ...
|
|
342
|
-
```
|
|
149
|
+
Import Protocol and runtime_checkable from typing. Apply runtime_checkable decorator. Define a Repository Protocol with generic type T. Add abstract async get method taking int id returning T or None, async create method taking dict data returning T, and async delete method taking int id returning bool.
|
|
343
150
|
|
|
344
151
|
ParamSpec for Decorators:
|
|
345
|
-
```python
|
|
346
|
-
from typing import ParamSpec, TypeVar, Callable
|
|
347
|
-
from functools import wraps
|
|
348
|
-
|
|
349
|
-
P = ParamSpec("P")
|
|
350
|
-
R = TypeVar("R")
|
|
351
|
-
|
|
352
|
-
def retry(times: int = 3) -> Callable[[Callable[P, R]], Callable[P, R]]:
|
|
353
|
-
def decorator(func: Callable[P, R]) -> Callable[P, R]:
|
|
354
|
-
@wraps(func)
|
|
355
|
-
async def wrapper(*args: P.args, **kwargs: P.kwargs) -> R:
|
|
356
|
-
for attempt in range(times):
|
|
357
|
-
try:
|
|
358
|
-
return await func(*args, **kwargs)
|
|
359
|
-
except Exception:
|
|
360
|
-
if attempt == times - 1:
|
|
361
|
-
raise
|
|
362
|
-
return wrapper
|
|
363
|
-
return decorator
|
|
364
|
-
```
|
|
365
|
-
|
|
366
|
-
### Package Management
|
|
367
|
-
|
|
368
|
-
pyproject.toml (Poetry):
|
|
369
|
-
```toml
|
|
370
|
-
[tool.poetry]
|
|
371
|
-
name = "my-project"
|
|
372
|
-
version = "1.0.0"
|
|
373
|
-
python = "^3.13"
|
|
374
|
-
|
|
375
|
-
[tool.poetry.dependencies]
|
|
376
|
-
fastapi = "^0.115.0"
|
|
377
|
-
pydantic = "^2.9.0"
|
|
378
|
-
sqlalchemy = {extras = ["asyncio"], version = "^2.0.0"}
|
|
379
152
|
|
|
380
|
-
|
|
381
|
-
pytest = "^8.0"
|
|
382
|
-
pytest-asyncio = "^0.24"
|
|
383
|
-
ruff = "^0.8"
|
|
153
|
+
Import ParamSpec, TypeVar, and Callable from typing, and wraps from functools. Define P as ParamSpec and R as TypeVar. Create a retry decorator function taking times defaulting to 3 that returns a callable wrapper. The inner decorator wraps the function and the wrapper iterates for the specified times, trying to await the function and re-raising on the last attempt.
|
|
384
154
|
|
|
385
|
-
|
|
386
|
-
line-length = 100
|
|
387
|
-
target-version = "py313"
|
|
388
|
-
|
|
389
|
-
[tool.pytest.ini_options]
|
|
390
|
-
asyncio_mode = "auto"
|
|
391
|
-
```
|
|
155
|
+
### Package Management
|
|
392
156
|
|
|
393
|
-
|
|
394
|
-
```bash
|
|
395
|
-
# Install uv
|
|
396
|
-
curl -LsSf https://astral.sh/uv/install.sh | sh
|
|
157
|
+
pyproject.toml with Poetry:
|
|
397
158
|
|
|
398
|
-
|
|
399
|
-
uv venv
|
|
159
|
+
In the tool.poetry section, set name, version, and python version constraint. Under dependencies, add fastapi, pydantic, and sqlalchemy with asyncio extra. Under dev dependencies, add pytest, pytest-asyncio, and ruff. Configure ruff with line-length and target-version. Set pytest asyncio_mode to auto in ini_options.
|
|
400
160
|
|
|
401
|
-
|
|
402
|
-
uv pip install -r requirements.txt
|
|
161
|
+
uv Fast Package Manager:
|
|
403
162
|
|
|
404
|
-
|
|
405
|
-
uv add fastapi
|
|
406
|
-
```
|
|
163
|
+
Install uv using curl with the install script from astral.sh. Create virtual environment with uv venv. Install dependencies with uv pip install from requirements.txt. Add dependencies with uv add command.
|
|
407
164
|
|
|
408
165
|
---
|
|
409
166
|
|
|
410
167
|
## Advanced Implementation (10+ minutes)
|
|
411
168
|
|
|
412
169
|
For comprehensive coverage including:
|
|
413
|
-
|
|
414
|
-
-
|
|
415
|
-
-
|
|
170
|
+
|
|
171
|
+
- Production deployment patterns for Docker and Kubernetes
|
|
172
|
+
- Advanced async patterns including task groups and semaphores
|
|
173
|
+
- Data science integration with numpy, pandas, and polars
|
|
416
174
|
- Performance optimization techniques
|
|
417
|
-
- Security best practices
|
|
175
|
+
- Security best practices following OWASP patterns
|
|
418
176
|
- CI/CD integration patterns
|
|
419
177
|
|
|
420
178
|
See:
|
|
421
|
-
|
|
422
|
-
-
|
|
179
|
+
|
|
180
|
+
- reference.md for complete reference documentation
|
|
181
|
+
- examples.md for production-ready code examples
|
|
423
182
|
|
|
424
183
|
---
|
|
425
184
|
|
|
426
185
|
## Context7 Library Mappings
|
|
427
186
|
|
|
428
|
-
|
|
429
|
-
/
|
|
430
|
-
/
|
|
431
|
-
/
|
|
432
|
-
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
/pola-rs/polars - Fast DataFrame library
|
|
437
|
-
```
|
|
187
|
+
- tiangolo/fastapi for FastAPI async web framework
|
|
188
|
+
- django/django for Django web framework
|
|
189
|
+
- pydantic/pydantic for data validation with type annotations
|
|
190
|
+
- sqlalchemy/sqlalchemy for SQL toolkit and ORM
|
|
191
|
+
- pytest-dev/pytest for testing framework
|
|
192
|
+
- numpy/numpy for numerical computing
|
|
193
|
+
- pandas-dev/pandas for data analysis library
|
|
194
|
+
- pola-rs/polars for fast DataFrame library
|
|
438
195
|
|
|
439
196
|
---
|
|
440
197
|
|
|
441
198
|
## Works Well With
|
|
442
199
|
|
|
443
|
-
-
|
|
444
|
-
-
|
|
445
|
-
-
|
|
446
|
-
-
|
|
447
|
-
-
|
|
200
|
+
- moai-domain-backend for REST API and microservices architecture
|
|
201
|
+
- moai-domain-database for SQL patterns and ORM optimization
|
|
202
|
+
- moai-workflow-testing for TDD and testing strategies
|
|
203
|
+
- moai-essentials-debug for AI-powered debugging
|
|
204
|
+
- moai-foundation-quality for TRUST 5 quality principles
|
|
448
205
|
|
|
449
206
|
---
|
|
450
207
|
|
|
@@ -453,29 +210,22 @@ See:
|
|
|
453
210
|
Common Issues:
|
|
454
211
|
|
|
455
212
|
Python Version Check:
|
|
456
|
-
|
|
457
|
-
python
|
|
458
|
-
python -c "import sys; print(sys.version_info)"
|
|
459
|
-
```
|
|
213
|
+
|
|
214
|
+
Run python with version flag to verify 3.13 or later. Use python with -c flag to print sys.version_info for detailed version information.
|
|
460
215
|
|
|
461
216
|
Async Session Detached Error:
|
|
462
|
-
|
|
463
|
-
|
|
217
|
+
|
|
218
|
+
Set expire_on_commit to False in session configuration. Alternatively, use await session.refresh with the object after commit.
|
|
464
219
|
|
|
465
220
|
pytest asyncio Mode Warning:
|
|
466
|
-
|
|
467
|
-
|
|
468
|
-
[tool.pytest.ini_options]
|
|
469
|
-
asyncio_mode = "auto"
|
|
470
|
-
asyncio_default_fixture_loop_scope = "function"
|
|
471
|
-
```
|
|
221
|
+
|
|
222
|
+
In pyproject.toml under tool.pytest.ini_options, set asyncio_mode to auto and asyncio_default_fixture_loop_scope to function.
|
|
472
223
|
|
|
473
224
|
Pydantic v2 Migration:
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
- `from_orm()` requires `from_attributes=True` in ConfigDict
|
|
225
|
+
|
|
226
|
+
The parse_obj method is now model_validate. The parse_raw method is now model_validate_json. The from_orm functionality requires from_attributes set to True in ConfigDict.
|
|
477
227
|
|
|
478
228
|
---
|
|
479
229
|
|
|
480
|
-
Last Updated:
|
|
481
|
-
Status: Active (v1.
|
|
230
|
+
Last Updated: 2026-01-11
|
|
231
|
+
Status: Active (v1.1.0)
|