agentic-dev 0.2.10 → 0.2.12
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/README.md +50 -29
- package/bin/agentic-dev.mjs +656 -124
- package/lib/scaffold.mjs +109 -6
- package/package.json +8 -22
- package/.agent/prd.json +0 -29
- package/.agent/progress.txt +0 -1
- package/.agent/prompt.md +0 -21
- package/.agent/ralph-loop-state.json +0 -13
- package/.agent/ralph-supervisor-state.json +0 -12
- package/.agent/ralph-supervisor.sh +0 -238
- package/.agent/ralph.sh +0 -305
- package/.agent/runs/README.md +0 -7
- package/.agent/sdd-build-ast-audit.json +0 -13
- package/.claude/CLAUDE.md +0 -44
- package/.claude/agentic-dev.json +0 -3
- package/.claude/agents/ai-dev.md +0 -27
- package/.claude/agents/backend-dev.md +0 -26
- package/.claude/agents/db-dev.md +0 -26
- package/.claude/agents/devops.md +0 -27
- package/.claude/agents/frontend-dev.md +0 -25
- package/.claude/agents/github-ops.md +0 -25
- package/.claude/agents/test-dev.md +0 -26
- package/.claude/agents/uiux-designer.md +0 -25
- package/.claude/settings.json +0 -49
- package/.claude/settings.local.json +0 -8
- package/.claude/skills/sdd/SKILL.md +0 -189
- package/.claude/skills/sdd/agents/openai.yaml +0 -4
- package/.claude/skills/sdd/references/section-map.md +0 -67
- package/.claude/workspace-config.json +0 -3
- package/.codex/agentic-dev.json +0 -3
- package/.codex/agents/README.md +0 -22
- package/.codex/agents/api.toml +0 -11
- package/.codex/agents/architecture.toml +0 -11
- package/.codex/agents/ci.toml +0 -11
- package/.codex/agents/gitops.toml +0 -11
- package/.codex/agents/orchestrator.toml +0 -11
- package/.codex/agents/quality.toml +0 -11
- package/.codex/agents/runtime.toml +0 -11
- package/.codex/agents/security.toml +0 -11
- package/.codex/agents/specs.toml +0 -11
- package/.codex/agents/ui.toml +0 -11
- package/.codex/config.toml +0 -46
- package/.codex/skills/SKILL.md +0 -13
- package/.codex/skills/sdd/SKILL.md +0 -189
- package/.codex/skills/sdd/agents/openai.yaml +0 -4
- package/.codex/skills/sdd/references/section-map.md +0 -67
- package/.dockerignore +0 -8
- package/.env.example +0 -50
- package/.gitignore +0 -16
- package/AGENTS.md +0 -86
- package/SDD_SKILL.md +0 -589
- package/client/admin/.dockerignore +0 -3
- package/client/admin/.env.example +0 -1
- package/client/admin/Dockerfile +0 -16
- package/client/admin/Dockerfile.dev +0 -18
- package/client/admin/README.md +0 -20
- package/client/admin/index.html +0 -12
- package/client/admin/package.json +0 -41
- package/client/admin/postcss.config.js +0 -6
- package/client/admin/scripts/ui-parity-admin-adapter.mjs +0 -65
- package/client/admin/src/api/alerts.ts +0 -33
- package/client/admin/src/api/client.ts +0 -71
- package/client/admin/src/api/orders.ts +0 -33
- package/client/admin/src/api/support.ts +0 -11
- package/client/admin/src/app/App.tsx +0 -23
- package/client/admin/src/auth/AuthProvider.tsx +0 -122
- package/client/admin/src/auth/ProtectedRoute.tsx +0 -22
- package/client/admin/src/auth/auth-client.ts +0 -38
- package/client/admin/src/auth/types.ts +0 -18
- package/client/admin/src/components/AdminNotificationsDrawer.tsx +0 -162
- package/client/admin/src/components/AdminShell.tsx +0 -76
- package/client/admin/src/components/ui/button.tsx +0 -34
- package/client/admin/src/components/ui/input.tsx +0 -21
- package/client/admin/src/lib/cn.ts +0 -6
- package/client/admin/src/lib/specRouteCatalog.json +0 -30
- package/client/admin/src/lib/specScreens.json +0 -22
- package/client/admin/src/main.tsx +0 -17
- package/client/admin/src/pages/AdminDashboardPage.tsx +0 -171
- package/client/admin/src/pages/AdminLoginPage.tsx +0 -75
- package/client/admin/src/pages/AdminQueuePage.tsx +0 -107
- package/client/admin/src/pages/AdminSupportPage.tsx +0 -61
- package/client/admin/src/styles/globals.css +0 -17
- package/client/admin/src/theme-vars.ts +0 -18
- package/client/admin/src/theme.ts +0 -25
- package/client/admin/src/vite-env.d.ts +0 -1
- package/client/admin/tailwind.config.js +0 -8
- package/client/admin/tsconfig.json +0 -25
- package/client/admin/vite.config.ts +0 -12
- package/client/landing/.dockerignore +0 -3
- package/client/landing/.env.example +0 -1
- package/client/landing/Dockerfile +0 -16
- package/client/landing/Dockerfile.dev +0 -18
- package/client/landing/README.md +0 -18
- package/client/landing/index.html +0 -12
- package/client/landing/package.json +0 -41
- package/client/landing/postcss.config.js +0 -6
- package/client/landing/scripts/ui-parity-landing-adapter.mjs +0 -65
- package/client/landing/src/App.tsx +0 -21
- package/client/landing/src/api/catalog.ts +0 -30
- package/client/landing/src/api/client.ts +0 -30
- package/client/landing/src/auth/AuthProvider.tsx +0 -122
- package/client/landing/src/auth/ProtectedRoute.tsx +0 -22
- package/client/landing/src/auth/auth-client.ts +0 -38
- package/client/landing/src/auth/types.ts +0 -18
- package/client/landing/src/components/LandingShell.tsx +0 -34
- package/client/landing/src/lib/specRouteCatalog.json +0 -23
- package/client/landing/src/lib/specScreens.json +0 -17
- package/client/landing/src/main.tsx +0 -17
- package/client/landing/src/pages/LandingHomePage.tsx +0 -215
- package/client/landing/src/pages/LandingLoginPage.tsx +0 -90
- package/client/landing/src/pages/LandingWorkspacePage.tsx +0 -126
- package/client/landing/src/styles/globals.css +0 -17
- package/client/landing/src/theme-vars.ts +0 -16
- package/client/landing/src/theme.ts +0 -21
- package/client/landing/src/vite-env.d.ts +0 -1
- package/client/landing/tailwind.config.js +0 -8
- package/client/landing/tsconfig.json +0 -25
- package/client/landing/vite.config.ts +0 -12
- package/client/mobile/.dockerignore +0 -2
- package/client/mobile/.env.example +0 -1
- package/client/mobile/Dockerfile +0 -16
- package/client/mobile/Dockerfile.dev +0 -18
- package/client/mobile/README.md +0 -19
- package/client/mobile/index.html +0 -12
- package/client/mobile/package.json +0 -42
- package/client/mobile/postcss.config.js +0 -6
- package/client/mobile/scripts/ui-parity-mobile-adapter.mjs +0 -67
- package/client/mobile/src/App.tsx +0 -1
- package/client/mobile/src/api/client.ts +0 -62
- package/client/mobile/src/api/fulfillment.ts +0 -55
- package/client/mobile/src/api/shipping.ts +0 -56
- package/client/mobile/src/app/App.tsx +0 -23
- package/client/mobile/src/auth/AuthProvider.tsx +0 -122
- package/client/mobile/src/auth/ProtectedRoute.tsx +0 -27
- package/client/mobile/src/auth/auth-client.ts +0 -38
- package/client/mobile/src/auth/types.ts +0 -18
- package/client/mobile/src/components/InShell.tsx +0 -74
- package/client/mobile/src/components/ui/button.tsx +0 -35
- package/client/mobile/src/components/ui/card.tsx +0 -15
- package/client/mobile/src/components/ui/input.tsx +0 -21
- package/client/mobile/src/lib/cn.ts +0 -6
- package/client/mobile/src/lib/specRouteCatalog.json +0 -26
- package/client/mobile/src/lib/specScreens.json +0 -22
- package/client/mobile/src/lib/useSpeechRecognitionInput.ts +0 -271
- package/client/mobile/src/main.tsx +0 -17
- package/client/mobile/src/pages/DashboardPage.tsx +0 -172
- package/client/mobile/src/pages/FulfillmentPage.tsx +0 -138
- package/client/mobile/src/pages/LoginPage.tsx +0 -74
- package/client/mobile/src/pages/ShippingPage.tsx +0 -338
- package/client/mobile/src/styles/globals.css +0 -23
- package/client/mobile/src/theme-vars.ts +0 -16
- package/client/mobile/src/theme.ts +0 -21
- package/client/mobile/src/vite-env.d.ts +0 -1
- package/client/mobile/tailwind.config.js +0 -8
- package/client/mobile/tsconfig.json +0 -25
- package/client/mobile/vite.config.ts +0 -12
- package/client/web/.dockerignore +0 -3
- package/client/web/.env.example +0 -1
- package/client/web/Dockerfile +0 -16
- package/client/web/Dockerfile.dev +0 -18
- package/client/web/README.md +0 -47
- package/client/web/index.html +0 -12
- package/client/web/package.json +0 -42
- package/client/web/postcss.config.js +0 -6
- package/client/web/scripts/ui-parity-web-adapter.mjs +0 -66
- package/client/web/src/api/client.ts +0 -30
- package/client/web/src/api/orders.ts +0 -42
- package/client/web/src/app/App.tsx +0 -21
- package/client/web/src/auth/AuthProvider.tsx +0 -122
- package/client/web/src/auth/ProtectedRoute.tsx +0 -22
- package/client/web/src/auth/auth-client.ts +0 -38
- package/client/web/src/auth/types.ts +0 -18
- package/client/web/src/components/AppShell.tsx +0 -59
- package/client/web/src/components/ui/button.tsx +0 -35
- package/client/web/src/components/ui/card.tsx +0 -7
- package/client/web/src/components/ui/input.tsx +0 -21
- package/client/web/src/lib/cn.ts +0 -6
- package/client/web/src/lib/specRouteCatalog.json +0 -23
- package/client/web/src/lib/specScreens.json +0 -17
- package/client/web/src/main.tsx +0 -17
- package/client/web/src/pages/DashboardPage.tsx +0 -158
- package/client/web/src/pages/LoginPage.tsx +0 -72
- package/client/web/src/pages/OrdersPage.tsx +0 -123
- package/client/web/src/styles/globals.css +0 -17
- package/client/web/src/theme-vars.ts +0 -18
- package/client/web/src/theme.ts +0 -25
- package/client/web/src/vite-env.d.ts +0 -1
- package/client/web/tailwind.config.js +0 -8
- package/client/web/tsconfig.json +0 -25
- package/client/web/vite.config.ts +0 -12
- package/compose.yml +0 -206
- package/infra/compose/.env.dev.example +0 -28
- package/infra/compose/.env.prod.example +0 -29
- package/infra/compose/README.md +0 -35
- package/infra/compose/dev.yml +0 -125
- package/infra/compose/prod.yml +0 -126
- package/infra/terraform/README.md +0 -34
- package/infra/terraform/aws/data/.terraform.lock.hcl +0 -25
- package/infra/terraform/aws/data/README.md +0 -18
- package/infra/terraform/aws/data/main.tf +0 -147
- package/infra/terraform/aws/data/outputs.tf +0 -14
- package/infra/terraform/aws/data/variables.tf +0 -57
- package/infra/terraform/aws/data/versions.tf +0 -10
- package/infra/terraform/aws/domain/.terraform.lock.hcl +0 -25
- package/infra/terraform/aws/domain/README.md +0 -20
- package/infra/terraform/aws/domain/env/dev.tfvars.example +0 -6
- package/infra/terraform/aws/domain/env/prod.tfvars.example +0 -7
- package/infra/terraform/aws/domain/main.tf +0 -149
- package/infra/terraform/aws/domain/outputs.tf +0 -29
- package/infra/terraform/aws/domain/variables.tf +0 -58
- package/infra/terraform/aws/domain/versions.tf +0 -10
- package/infra/terraform/openstack/README.md +0 -38
- package/infra/terraform/openstack/dev/.terraform.lock.hcl +0 -24
- package/infra/terraform/openstack/dev/README.md +0 -18
- package/infra/terraform/openstack/dev/main.tf +0 -49
- package/infra/terraform/openstack/dev/providers.tf +0 -15
- package/infra/terraform/openstack/dev/terraform.tfvars.example +0 -54
- package/infra/terraform/openstack/dev/variables.tf +0 -210
- package/infra/terraform/openstack/dev/versions.tf +0 -10
- package/infra/terraform/openstack/modules/environment_host/main.tf +0 -143
- package/infra/terraform/openstack/modules/environment_host/outputs.tf +0 -25
- package/infra/terraform/openstack/modules/environment_host/templates/docker-host-user-data.sh.tftpl +0 -40
- package/infra/terraform/openstack/modules/environment_host/variables.tf +0 -145
- package/infra/terraform/openstack/modules/environment_host/versions.tf +0 -7
- package/infra/terraform/openstack/prod/.terraform.lock.hcl +0 -24
- package/infra/terraform/openstack/prod/README.md +0 -18
- package/infra/terraform/openstack/prod/main.tf +0 -49
- package/infra/terraform/openstack/prod/providers.tf +0 -15
- package/infra/terraform/openstack/prod/terraform.tfvars.example +0 -55
- package/infra/terraform/openstack/prod/variables.tf +0 -210
- package/infra/terraform/openstack/prod/versions.tf +0 -10
- package/infra/terraform/openstack/server/.terraform.lock.hcl +0 -45
- package/infra/terraform/openstack/server/README.md +0 -47
- package/infra/terraform/openstack/server/main.tf +0 -161
- package/infra/terraform/openstack/server/outputs.tf +0 -30
- package/infra/terraform/openstack/server/providers.tf +0 -30
- package/infra/terraform/openstack/server/templates/server-user-data.sh.tftpl +0 -50
- package/infra/terraform/openstack/server/variables.tf +0 -233
- package/infra/terraform/openstack/server/zz_aspace.auto.tfvars.example.json +0 -29
- package/pnpm-workspace.yaml +0 -2
- package/scripts/dev/audit_sdd_build_ast.py +0 -277
- package/sdd/01_planning/01_feature/INDEX.md +0 -16
- package/sdd/01_planning/01_feature/README.md +0 -76
- package/sdd/01_planning/01_feature/alerts_feature_spec.md +0 -55
- package/sdd/01_planning/01_feature/auth_feature_spec.md +0 -57
- package/sdd/01_planning/01_feature/catalog_feature_spec.md +0 -61
- package/sdd/01_planning/01_feature/fulfillment_feature_spec.md +0 -58
- package/sdd/01_planning/01_feature/health_feature_spec.md +0 -52
- package/sdd/01_planning/01_feature/inventory_feature_spec.md +0 -60
- package/sdd/01_planning/01_feature/order_feature_spec.md +0 -63
- package/sdd/01_planning/01_feature/shipping_feature_spec.md +0 -55
- package/sdd/01_planning/01_feature/support_feature_spec.md +0 -53
- package/sdd/01_planning/01_feature/user_feature_spec.md +0 -54
- package/sdd/01_planning/02_screen/INDEX.md +0 -13
- package/sdd/01_planning/02_screen/README.md +0 -41
- package/sdd/01_planning/02_screen/admin_screen_spec.pdf +0 -0
- package/sdd/01_planning/02_screen/assets/README.md +0 -16
- package/sdd/01_planning/02_screen/assets/example/README.md +0 -13
- package/sdd/01_planning/02_screen/landing_screen_spec.pdf +0 -0
- package/sdd/01_planning/02_screen/mobile_screen_spec.pdf +0 -0
- package/sdd/01_planning/02_screen/web_screen_spec.pdf +0 -0
- package/sdd/01_planning/03_architecture/INDEX.md +0 -9
- package/sdd/01_planning/03_architecture/README.md +0 -25
- package/sdd/01_planning/03_architecture/architecture_document_structure.md +0 -77
- package/sdd/01_planning/03_architecture/backend/README.md +0 -10
- package/sdd/01_planning/03_architecture/frontend/README.md +0 -12
- package/sdd/01_planning/03_architecture/infra/README.md +0 -10
- package/sdd/01_planning/03_architecture/tech-research/README.md +0 -4
- package/sdd/01_planning/03_architecture/templates_system_architecture.md +0 -84
- package/sdd/01_planning/04_data/INDEX.md +0 -4
- package/sdd/01_planning/04_data/README.md +0 -10
- package/sdd/01_planning/04_data/templates_data_modeling.md +0 -119
- package/sdd/01_planning/05_api/README.md +0 -12
- package/sdd/01_planning/05_api/templates_api_contract.md +0 -90
- package/sdd/01_planning/06_iac/README.md +0 -11
- package/sdd/01_planning/06_iac/templates_runtime_and_cicd_baseline.md +0 -46
- package/sdd/01_planning/07_integration/README.md +0 -11
- package/sdd/01_planning/07_integration/templates_frontend_api_integration.md +0 -46
- package/sdd/01_planning/08_nonfunctional/README.md +0 -7
- package/sdd/01_planning/09_security/README.md +0 -7
- package/sdd/01_planning/10_test/README.md +0 -12
- package/sdd/01_planning/10_test/templates_test_strategy.md +0 -60
- package/sdd/01_planning/INDEX.md +0 -19
- package/sdd/01_planning/README.md +0 -17
- package/sdd/02_plan/01_feature/README.md +0 -34
- package/sdd/02_plan/01_feature/_feature_todo_template.md +0 -29
- package/sdd/02_plan/02_screen/INDEX.md +0 -19
- package/sdd/02_plan/02_screen/README.md +0 -39
- package/sdd/02_plan/02_screen/_screen_todo_template.md +0 -60
- package/sdd/02_plan/03_architecture/README.md +0 -23
- package/sdd/02_plan/03_architecture/architecture_document_governance.md +0 -40
- package/sdd/02_plan/03_architecture/build_ast_runtime_tree_governance.md +0 -53
- package/sdd/02_plan/03_architecture/repository_governance.md +0 -39
- package/sdd/02_plan/03_architecture/runtime_and_structure_governance.md +0 -38
- package/sdd/02_plan/03_architecture/templates-hexagonal-template-architecture.md +0 -9
- package/sdd/02_plan/03_architecture/toolchain_governance.md +0 -98
- package/sdd/02_plan/04_data/README.md +0 -5
- package/sdd/02_plan/05_api/README.md +0 -5
- package/sdd/02_plan/06_iac/README.md +0 -11
- package/sdd/02_plan/06_iac/dev_runtime_delivery.md +0 -36
- package/sdd/02_plan/06_iac/template_runtime_delivery.md +0 -50
- package/sdd/02_plan/07_integration/README.md +0 -5
- package/sdd/02_plan/07_integration/frontend_live_integration.md +0 -31
- package/sdd/02_plan/08_nonfunctional/README.md +0 -5
- package/sdd/02_plan/08_nonfunctional/repository_hygiene.md +0 -26
- package/sdd/02_plan/09_security/README.md +0 -5
- package/sdd/02_plan/10_test/README.md +0 -11
- package/sdd/02_plan/10_test/regression_verification.md +0 -39
- package/sdd/02_plan/10_test/templates/README.md +0 -8
- package/sdd/02_plan/10_test/templates/ui_parity_web_contract.template.yaml +0 -23
- package/sdd/02_plan/10_test/verification_strategy.md +0 -43
- package/sdd/02_plan/99_generated/from_planning/ui_parity/.gitkeep +0 -1
- package/sdd/02_plan/README.md +0 -40
- package/sdd/03_build/01_feature/README.md +0 -20
- package/sdd/03_build/01_feature/domain/README.md +0 -3
- package/sdd/03_build/01_feature/domain/account_and_access.md +0 -20
- package/sdd/03_build/01_feature/domain/catalog_and_inventory.md +0 -20
- package/sdd/03_build/01_feature/domain/ordering_and_fulfillment.md +0 -21
- package/sdd/03_build/01_feature/domain/support_and_observability.md +0 -21
- package/sdd/03_build/01_feature/domain_surfaces.md +0 -28
- package/sdd/03_build/01_feature/service/README.md +0 -3
- package/sdd/03_build/01_feature/service/admin_surface.md +0 -15
- package/sdd/03_build/01_feature/service/landing_surface.md +0 -13
- package/sdd/03_build/01_feature/service/mobile_surface.md +0 -14
- package/sdd/03_build/01_feature/service/web_surface.md +0 -14
- package/sdd/03_build/02_screen/README.md +0 -25
- package/sdd/03_build/02_screen/_screen_build_template.md +0 -26
- package/sdd/03_build/02_screen/admin/README.md +0 -5
- package/sdd/03_build/02_screen/landing/README.md +0 -5
- package/sdd/03_build/02_screen/mobile/README.md +0 -5
- package/sdd/03_build/02_screen/web/README.md +0 -5
- package/sdd/03_build/03_architecture/README.md +0 -10
- package/sdd/03_build/03_architecture/architecture_document_governance.md +0 -30
- package/sdd/03_build/03_architecture/build_ast_runtime_tree_governance.md +0 -24
- package/sdd/03_build/03_architecture/repository_governance.md +0 -18
- package/sdd/03_build/03_architecture/toolchain_governance.md +0 -36
- package/sdd/03_build/06_iac/README.md +0 -3
- package/sdd/03_build/06_iac/dev_runtime_delivery.md +0 -10
- package/sdd/03_build/06_iac/template_runtime_delivery.md +0 -49
- package/sdd/03_build/07_integration/README.md +0 -3
- package/sdd/03_build/07_integration/frontend_live_integration.md +0 -11
- package/sdd/03_build/08_nonfunctional/README.md +0 -3
- package/sdd/03_build/08_nonfunctional/repository_hygiene.md +0 -10
- package/sdd/03_build/10_test/README.md +0 -9
- package/sdd/03_build/10_test/regression_verification.md +0 -16
- package/sdd/03_build/10_test/verification_harness.md +0 -11
- package/sdd/03_build/README.md +0 -35
- package/sdd/03_verify/01_feature/README.md +0 -5
- package/sdd/03_verify/01_feature/domain_verification.md +0 -14
- package/sdd/03_verify/01_feature/service_verification.md +0 -22
- package/sdd/03_verify/02_screen/README.md +0 -6
- package/sdd/03_verify/02_screen/_screen_verify_template.md +0 -20
- package/sdd/03_verify/02_screen/admin/README.md +0 -4
- package/sdd/03_verify/02_screen/landing/README.md +0 -4
- package/sdd/03_verify/02_screen/mobile/README.md +0 -4
- package/sdd/03_verify/02_screen/web/README.md +0 -4
- package/sdd/03_verify/03_architecture/README.md +0 -10
- package/sdd/03_verify/03_architecture/architecture_document_governance.md +0 -15
- package/sdd/03_verify/03_architecture/build_ast_runtime_tree_governance.md +0 -28
- package/sdd/03_verify/03_architecture/repository_governance.md +0 -16
- package/sdd/03_verify/03_architecture/toolchain_governance.md +0 -58
- package/sdd/03_verify/06_iac/README.md +0 -3
- package/sdd/03_verify/06_iac/dev_runtime_delivery.md +0 -10
- package/sdd/03_verify/06_iac/template_runtime_delivery.md +0 -42
- package/sdd/03_verify/07_integration/README.md +0 -3
- package/sdd/03_verify/07_integration/frontend_live_integration.md +0 -16
- package/sdd/03_verify/08_nonfunctional/README.md +0 -3
- package/sdd/03_verify/08_nonfunctional/repository_hygiene.md +0 -14
- package/sdd/03_verify/10_test/README.md +0 -9
- package/sdd/03_verify/10_test/regression_verification.md +0 -16
- package/sdd/03_verify/10_test/ui_parity/README.md +0 -4
- package/sdd/03_verify/10_test/ui_parity/loop_runs/.gitkeep +0 -0
- package/sdd/03_verify/10_test/ui_parity/reference/.gitkeep +0 -0
- package/sdd/03_verify/10_test/ui_parity/staged_runs/.gitkeep +0 -0
- package/sdd/03_verify/10_test/verification_harness.md +0 -17
- package/sdd/03_verify/README.md +0 -22
- package/sdd/05_operate/01_runbooks/.gitkeep +0 -1
- package/sdd/05_operate/01_runbooks/README.md +0 -4
- package/sdd/05_operate/02_delivery_status/README.md +0 -4
- package/sdd/05_operate/02_delivery_status/service_status.md +0 -16
- package/sdd/05_operate/README.md +0 -12
- package/sdd/99_toolchain/01_automation/.gitkeep +0 -1
- package/sdd/99_toolchain/01_automation/README.md +0 -76
- package/sdd/99_toolchain/01_automation/agentic-dev/analyze_proof_results.py +0 -132
- package/sdd/99_toolchain/01_automation/agentic-dev/analyze_route_gap.py +0 -85
- package/sdd/99_toolchain/01_automation/agentic-dev/assets/repo-contract.template.json +0 -75
- package/sdd/99_toolchain/01_automation/agentic-dev/bootstrap_frontend_parity.sh +0 -84
- package/sdd/99_toolchain/01_automation/agentic-dev/init_frontend_parity.sh +0 -33
- package/sdd/99_toolchain/01_automation/agentic-dev/init_repo_contract.sh +0 -51
- package/sdd/99_toolchain/01_automation/agentic-dev/repo-contract.json +0 -76
- package/sdd/99_toolchain/01_automation/agentic-dev/resolve_frontend_target.py +0 -52
- package/sdd/99_toolchain/01_automation/agentic-dev/resolve_repo_contract.py +0 -56
- package/sdd/99_toolchain/01_automation/agentic-dev/run_frontend_target.sh +0 -100
- package/sdd/99_toolchain/01_automation/agentic-dev/run_repo_phase.sh +0 -140
- package/sdd/99_toolchain/01_automation/agentic-dev/validate_json_schema.py +0 -39
- package/sdd/99_toolchain/01_automation/agentic-parity-harness-design.md +0 -291
- package/sdd/99_toolchain/01_automation/assets/admin_screen_capture/dashboard.png +0 -0
- package/sdd/99_toolchain/01_automation/assets/admin_screen_capture/login.png +0 -0
- package/sdd/99_toolchain/01_automation/assets/admin_screen_capture/queue.png +0 -0
- package/sdd/99_toolchain/01_automation/assets/admin_screen_capture/support.png +0 -0
- package/sdd/99_toolchain/01_automation/assets/landing_screen_capture/home.png +0 -0
- package/sdd/99_toolchain/01_automation/assets/landing_screen_capture/login.png +0 -0
- package/sdd/99_toolchain/01_automation/assets/landing_screen_capture/workspace.png +0 -0
- package/sdd/99_toolchain/01_automation/assets/mobile_screen_capture/dashboard.png +0 -0
- package/sdd/99_toolchain/01_automation/assets/mobile_screen_capture/fulfillment.png +0 -0
- package/sdd/99_toolchain/01_automation/assets/mobile_screen_capture/login.png +0 -0
- package/sdd/99_toolchain/01_automation/assets/web_screen_capture/dashboard.png +0 -0
- package/sdd/99_toolchain/01_automation/assets/web_screen_capture/login.png +0 -0
- package/sdd/99_toolchain/01_automation/assets/web_screen_capture/orders.png +0 -0
- package/sdd/99_toolchain/01_automation/build_asset_recipes.py +0 -10
- package/sdd/99_toolchain/01_automation/build_screen_spec_pdf.py +0 -427
- package/sdd/99_toolchain/01_automation/capture_screen_assets.mjs +0 -148
- package/sdd/99_toolchain/01_automation/harness-layout.md +0 -34
- package/sdd/99_toolchain/01_automation/parity-execution-tooling-design.md +0 -319
- package/sdd/99_toolchain/01_automation/playwright_exactness_manifest.py +0 -21
- package/sdd/99_toolchain/01_automation/run_playwright_exactness.py +0 -87
- package/sdd/99_toolchain/01_automation/screen_spec_manifest.py +0 -321
- package/sdd/99_toolchain/01_automation/spec_asset_builder.py +0 -274
- package/sdd/99_toolchain/01_automation/ui-contract-projection.md +0 -79
- package/sdd/99_toolchain/01_automation/ui-parity/README.md +0 -60
- package/sdd/99_toolchain/01_automation/ui-parity/cli/extract-reference-pages.mjs +0 -2
- package/sdd/99_toolchain/01_automation/ui-parity/cli/materialize-reference-assets.mjs +0 -58
- package/sdd/99_toolchain/01_automation/ui-parity/cli/normalize-reference-assets.mjs +0 -2
- package/sdd/99_toolchain/01_automation/ui-parity/cli/route-gap-report.mjs +0 -187
- package/sdd/99_toolchain/01_automation/ui-parity/cli/run-proof.mjs +0 -50
- package/sdd/99_toolchain/01_automation/ui-parity/cli/scaffold-contract.mjs +0 -62
- package/sdd/99_toolchain/01_automation/ui-parity/cli/upload-parity1.mjs +0 -2
- package/sdd/99_toolchain/01_automation/ui-parity/contracts/collector-metadata.schema.json +0 -33
- package/sdd/99_toolchain/01_automation/ui-parity/contracts/proof-result.schema.json +0 -76
- package/sdd/99_toolchain/01_automation/ui-parity/contracts/route-gap-report.schema.json +0 -95
- package/sdd/99_toolchain/01_automation/ui-parity/core/capture-runner.mjs +0 -55
- package/sdd/99_toolchain/01_automation/ui-parity/core/load-adapter.mjs +0 -25
- package/sdd/99_toolchain/01_automation/ui-parity/core/load-contract.mjs +0 -81
- package/sdd/99_toolchain/01_automation/ui-parity/core/paths.mjs +0 -23
- package/sdd/99_toolchain/01_automation/ui-parity/core/proof-runner.mjs +0 -255
- package/sdd/99_toolchain/01_automation/ui-parity/interfaces/ui-parity-artifact-layout.md +0 -23
- package/sdd/99_toolchain/01_automation/ui-parity/interfaces/ui-parity-proof-interface.md +0 -60
- package/sdd/99_toolchain/01_automation/ui-parity/interfaces/ui-parity-route-gap-interface.md +0 -82
- package/sdd/99_toolchain/01_automation/ui-parity/runtime/playwright-runtime.mjs +0 -16
- package/sdd/99_toolchain/01_automation/ui-parity/runtime/static-runtime.mjs +0 -6
- package/sdd/99_toolchain/02_policies/.gitkeep +0 -1
- package/sdd/99_toolchain/02_policies/build-ast-governance-policy.md +0 -22
- package/sdd/99_toolchain/02_policies/compose-runtime-baseline-policy.md +0 -24
- package/sdd/99_toolchain/02_policies/convention-storage-policy.md +0 -26
- package/sdd/99_toolchain/02_policies/main-push-before-dev-deploy-policy.md +0 -27
- package/sdd/99_toolchain/02_policies/regression-verification-policy.md +0 -22
- package/sdd/99_toolchain/03_templates/.gitkeep +0 -1
- package/sdd/99_toolchain/03_templates/asset_recipe_manifest.example.py +0 -38
- package/sdd/99_toolchain/03_templates/generated_assets/README.md +0 -11
- package/sdd/99_toolchain/03_templates/generated_assets/example-brand-lockup.svg +0 -3
- package/sdd/99_toolchain/03_templates/generated_assets/example-brand-mark.svg +0 -3
- package/sdd/99_toolchain/03_templates/generated_assets/example-brand-wordmark.svg +0 -3
- package/sdd/99_toolchain/03_templates/playwright_exactness_manifest.example.py +0 -21
- package/sdd/99_toolchain/README.md +0 -23
- package/sdd/README.md +0 -21
- package/server/.dockerignore +0 -4
- package/server/.env.example +0 -19
- package/server/Dockerfile +0 -22
- package/server/Dockerfile.dev +0 -19
- package/server/README.md +0 -33
- package/server/__init__.py +0 -0
- package/server/api/__init__.py +0 -1
- package/server/api/http/__init__.py +0 -4
- package/server/api/http/app.py +0 -53
- package/server/api/http/router.py +0 -24
- package/server/config.py +0 -52
- package/server/contexts/__init__.py +0 -12
- package/server/contexts/alerts/__init__.py +0 -1
- package/server/contexts/alerts/application/__init__.py +0 -13
- package/server/contexts/alerts/application/services.py +0 -41
- package/server/contexts/alerts/contracts/__init__.py +0 -3
- package/server/contexts/alerts/contracts/http/__init__.py +0 -3
- package/server/contexts/alerts/contracts/http/router.py +0 -37
- package/server/contexts/alerts/domain/__init__.py +0 -15
- package/server/contexts/alerts/domain/models.py +0 -29
- package/server/contexts/alerts/infrastructure/__init__.py +0 -11
- package/server/contexts/alerts/infrastructure/repository.py +0 -41
- package/server/contexts/auth/__init__.py +0 -1
- package/server/contexts/auth/application/__init__.py +0 -3
- package/server/contexts/auth/application/ports.py +0 -10
- package/server/contexts/auth/application/services.py +0 -64
- package/server/contexts/auth/contracts/__init__.py +0 -4
- package/server/contexts/auth/contracts/http/__init__.py +0 -4
- package/server/contexts/auth/contracts/http/dependencies.py +0 -37
- package/server/contexts/auth/contracts/http/router.py +0 -19
- package/server/contexts/auth/domain/__init__.py +0 -3
- package/server/contexts/auth/domain/models.py +0 -24
- package/server/contexts/auth/infrastructure/__init__.py +0 -4
- package/server/contexts/auth/infrastructure/adapters/memory.py +0 -19
- package/server/contexts/auth/infrastructure/adapters/mongodb.py +0 -24
- package/server/contexts/auth/infrastructure/adapters/sqlalchemy.py +0 -74
- package/server/contexts/auth/infrastructure/repository.py +0 -28
- package/server/contexts/catalog/__init__.py +0 -1
- package/server/contexts/catalog/application/__init__.py +0 -28
- package/server/contexts/catalog/application/ports.py +0 -15
- package/server/contexts/catalog/application/services.py +0 -154
- package/server/contexts/catalog/contracts/__init__.py +0 -3
- package/server/contexts/catalog/contracts/http/__init__.py +0 -3
- package/server/contexts/catalog/contracts/http/router.py +0 -60
- package/server/contexts/catalog/domain/__init__.py +0 -45
- package/server/contexts/catalog/domain/models.py +0 -113
- package/server/contexts/catalog/infrastructure/__init__.py +0 -4
- package/server/contexts/catalog/infrastructure/adapters/memory.py +0 -62
- package/server/contexts/catalog/infrastructure/repository.py +0 -8
- package/server/contexts/fulfillment/__init__.py +0 -1
- package/server/contexts/fulfillment/application/__init__.py +0 -13
- package/server/contexts/fulfillment/application/ports.py +0 -20
- package/server/contexts/fulfillment/application/services.py +0 -85
- package/server/contexts/fulfillment/contracts/__init__.py +0 -3
- package/server/contexts/fulfillment/contracts/http/__init__.py +0 -3
- package/server/contexts/fulfillment/contracts/http/router.py +0 -40
- package/server/contexts/fulfillment/domain/__init__.py +0 -25
- package/server/contexts/fulfillment/domain/models.py +0 -73
- package/server/contexts/fulfillment/infrastructure/__init__.py +0 -13
- package/server/contexts/fulfillment/infrastructure/adapters/memory.py +0 -43
- package/server/contexts/fulfillment/infrastructure/repository.py +0 -97
- package/server/contexts/health/__init__.py +0 -1
- package/server/contexts/health/application/__init__.py +0 -3
- package/server/contexts/health/application/services.py +0 -2
- package/server/contexts/health/contracts/__init__.py +0 -3
- package/server/contexts/health/contracts/http/__init__.py +0 -3
- package/server/contexts/health/contracts/http/router.py +0 -10
- package/server/contexts/inventory/__init__.py +0 -1
- package/server/contexts/inventory/application/__init__.py +0 -28
- package/server/contexts/inventory/application/ports.py +0 -11
- package/server/contexts/inventory/application/services.py +0 -214
- package/server/contexts/inventory/contracts/__init__.py +0 -3
- package/server/contexts/inventory/contracts/http/__init__.py +0 -3
- package/server/contexts/inventory/contracts/http/router.py +0 -82
- package/server/contexts/inventory/domain/__init__.py +0 -33
- package/server/contexts/inventory/domain/models.py +0 -93
- package/server/contexts/inventory/infrastructure/__init__.py +0 -4
- package/server/contexts/inventory/infrastructure/adapters/memory.py +0 -24
- package/server/contexts/inventory/infrastructure/repository.py +0 -8
- package/server/contexts/orders/__init__.py +0 -1
- package/server/contexts/orders/application/__init__.py +0 -19
- package/server/contexts/orders/application/services.py +0 -127
- package/server/contexts/orders/contracts/__init__.py +0 -3
- package/server/contexts/orders/contracts/http/__init__.py +0 -3
- package/server/contexts/orders/contracts/http/router.py +0 -82
- package/server/contexts/orders/domain/__init__.py +0 -29
- package/server/contexts/orders/domain/models.py +0 -95
- package/server/contexts/orders/infrastructure/__init__.py +0 -7
- package/server/contexts/orders/infrastructure/repository.py +0 -104
- package/server/contexts/shipping/__init__.py +0 -1
- package/server/contexts/shipping/application/__init__.py +0 -13
- package/server/contexts/shipping/application/services.py +0 -92
- package/server/contexts/shipping/contracts/__init__.py +0 -3
- package/server/contexts/shipping/contracts/http/__init__.py +0 -3
- package/server/contexts/shipping/contracts/http/router.py +0 -40
- package/server/contexts/shipping/domain/__init__.py +0 -19
- package/server/contexts/shipping/domain/models.py +0 -48
- package/server/contexts/shipping/infrastructure/__init__.py +0 -9
- package/server/contexts/shipping/infrastructure/repository.py +0 -50
- package/server/contexts/support/__init__.py +0 -1
- package/server/contexts/support/application/__init__.py +0 -13
- package/server/contexts/support/application/services.py +0 -29
- package/server/contexts/support/contracts/__init__.py +0 -3
- package/server/contexts/support/contracts/http/__init__.py +0 -3
- package/server/contexts/support/contracts/http/router.py +0 -40
- package/server/contexts/support/domain/__init__.py +0 -13
- package/server/contexts/support/domain/models.py +0 -27
- package/server/contexts/support/infrastructure/__init__.py +0 -11
- package/server/contexts/support/infrastructure/repository.py +0 -70
- package/server/contexts/user/__init__.py +0 -1
- package/server/contexts/user/application/__init__.py +0 -3
- package/server/contexts/user/application/ports.py +0 -11
- package/server/contexts/user/application/services.py +0 -44
- package/server/contexts/user/contracts/__init__.py +0 -3
- package/server/contexts/user/contracts/http/__init__.py +0 -3
- package/server/contexts/user/contracts/http/router.py +0 -26
- package/server/contexts/user/domain/__init__.py +0 -3
- package/server/contexts/user/domain/models.py +0 -22
- package/server/contexts/user/infrastructure/__init__.py +0 -3
- package/server/contexts/user/infrastructure/adapters/memory.py +0 -27
- package/server/contexts/user/infrastructure/adapters/mongodb.py +0 -41
- package/server/contexts/user/infrastructure/adapters/sqlalchemy.py +0 -94
- package/server/contexts/user/infrastructure/factory.py +0 -28
- package/server/data/README.md +0 -24
- package/server/data/bootstrap/alerts.json +0 -38
- package/server/data/bootstrap/auth_accounts.json +0 -18
- package/server/data/bootstrap/catalog_products.json +0 -179
- package/server/data/bootstrap/fulfillment_events.json +0 -5
- package/server/data/bootstrap/fulfillment_notes.json +0 -5
- package/server/data/bootstrap/fulfillment_tasks.json +0 -50
- package/server/data/bootstrap/inventory_levels.json +0 -80
- package/server/data/bootstrap/orders.json +0 -62
- package/server/data/bootstrap/shipping_shipments.json +0 -50
- package/server/data/bootstrap/support_faqs.json +0 -26
- package/server/data/bootstrap/users.json +0 -20
- package/server/data/bootstrap_loader.py +0 -15
- package/server/docker-entrypoint.sh +0 -56
- package/server/main.py +0 -3
- package/server/pyproject.toml +0 -36
- package/server/shared/__init__.py +0 -1
- package/server/shared/application/__init__.py +0 -3
- package/server/shared/application/health.py +0 -2
- package/server/shared/infrastructure/__init__.py +0 -10
- package/server/shared/infrastructure/runtime.py +0 -6
- package/server/shared/infrastructure/security.py +0 -33
- package/server/tests/e2e/test_domain_feature_flows.py +0 -483
- package/server/tests/test_health.py +0 -49
- package/server/uv.lock +0 -1169
|
@@ -1,82 +0,0 @@
|
|
|
1
|
-
from fastapi import APIRouter, Depends, HTTPException
|
|
2
|
-
|
|
3
|
-
from contexts.auth.contracts.http.dependencies import (
|
|
4
|
-
require_admin_user,
|
|
5
|
-
require_authenticated_user,
|
|
6
|
-
)
|
|
7
|
-
from contexts.orders.application import (
|
|
8
|
-
create_order as create_order_service,
|
|
9
|
-
get_admin_order_overview,
|
|
10
|
-
get_admin_queue,
|
|
11
|
-
get_order_list,
|
|
12
|
-
get_order_overview,
|
|
13
|
-
update_order_status as update_order_status_service,
|
|
14
|
-
)
|
|
15
|
-
from contexts.orders.domain import (
|
|
16
|
-
AdminOrderOverview,
|
|
17
|
-
AdminQueueItem,
|
|
18
|
-
CreateOrderCommand,
|
|
19
|
-
OrderOverview,
|
|
20
|
-
OrderRecord,
|
|
21
|
-
OrderStatusTransition,
|
|
22
|
-
OrderSummary,
|
|
23
|
-
UpdateOrderStatusCommand,
|
|
24
|
-
)
|
|
25
|
-
|
|
26
|
-
router = APIRouter(prefix="/orders", tags=["orders"])
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
@router.get(
|
|
30
|
-
"/overview",
|
|
31
|
-
response_model=OrderOverview,
|
|
32
|
-
dependencies=[Depends(require_authenticated_user)],
|
|
33
|
-
)
|
|
34
|
-
def order_overview() -> OrderOverview:
|
|
35
|
-
return get_order_overview()
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
@router.get("", response_model=list[OrderSummary], dependencies=[Depends(require_authenticated_user)])
|
|
39
|
-
def list_orders() -> list[OrderSummary]:
|
|
40
|
-
return get_order_list()
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
@router.post(
|
|
44
|
-
"",
|
|
45
|
-
response_model=OrderRecord,
|
|
46
|
-
status_code=201,
|
|
47
|
-
dependencies=[Depends(require_authenticated_user)],
|
|
48
|
-
)
|
|
49
|
-
def create_order(command: CreateOrderCommand) -> OrderRecord:
|
|
50
|
-
return create_order_service(command)
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
@router.get(
|
|
54
|
-
"/admin/overview",
|
|
55
|
-
response_model=AdminOrderOverview,
|
|
56
|
-
dependencies=[Depends(require_admin_user)],
|
|
57
|
-
)
|
|
58
|
-
def admin_order_overview() -> AdminOrderOverview:
|
|
59
|
-
return get_admin_order_overview()
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
@router.get(
|
|
63
|
-
"/admin/queue",
|
|
64
|
-
response_model=list[AdminQueueItem],
|
|
65
|
-
dependencies=[Depends(require_admin_user)],
|
|
66
|
-
)
|
|
67
|
-
def admin_queue() -> list[AdminQueueItem]:
|
|
68
|
-
return get_admin_queue()
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
@router.patch(
|
|
72
|
-
"/{order_id}/status",
|
|
73
|
-
response_model=OrderStatusTransition,
|
|
74
|
-
dependencies=[Depends(require_authenticated_user)],
|
|
75
|
-
)
|
|
76
|
-
def update_order_status(
|
|
77
|
-
order_id: str, command: UpdateOrderStatusCommand
|
|
78
|
-
) -> OrderStatusTransition:
|
|
79
|
-
try:
|
|
80
|
-
return update_order_status_service(order_id, command)
|
|
81
|
-
except LookupError as exc:
|
|
82
|
-
raise HTTPException(status_code=404, detail=str(exc)) from exc
|
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
from .models import (
|
|
2
|
-
AdminOrderOverview,
|
|
3
|
-
AdminQueueItem,
|
|
4
|
-
CreateOrderCommand,
|
|
5
|
-
DashboardStat,
|
|
6
|
-
OrderActivity,
|
|
7
|
-
OrderDetail,
|
|
8
|
-
OrderOverview,
|
|
9
|
-
OrderRecord,
|
|
10
|
-
OrderStatusTransition,
|
|
11
|
-
OrderSummary,
|
|
12
|
-
StageStatus,
|
|
13
|
-
UpdateOrderStatusCommand,
|
|
14
|
-
)
|
|
15
|
-
|
|
16
|
-
__all__ = [
|
|
17
|
-
"AdminOrderOverview",
|
|
18
|
-
"AdminQueueItem",
|
|
19
|
-
"CreateOrderCommand",
|
|
20
|
-
"DashboardStat",
|
|
21
|
-
"OrderActivity",
|
|
22
|
-
"OrderDetail",
|
|
23
|
-
"OrderOverview",
|
|
24
|
-
"OrderRecord",
|
|
25
|
-
"OrderStatusTransition",
|
|
26
|
-
"OrderSummary",
|
|
27
|
-
"StageStatus",
|
|
28
|
-
"UpdateOrderStatusCommand",
|
|
29
|
-
]
|
|
@@ -1,95 +0,0 @@
|
|
|
1
|
-
from pydantic import BaseModel
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
class OrderRecord(BaseModel):
|
|
5
|
-
id: str
|
|
6
|
-
product_id: str
|
|
7
|
-
product_name: str
|
|
8
|
-
customer_name: str
|
|
9
|
-
seller_name: str
|
|
10
|
-
status: str
|
|
11
|
-
fulfillment_status: str
|
|
12
|
-
created_at: str
|
|
13
|
-
amount_krw: int
|
|
14
|
-
risk: str
|
|
15
|
-
stage: str
|
|
16
|
-
sla: str
|
|
17
|
-
is_new_today: bool
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
class DashboardStat(BaseModel):
|
|
21
|
-
label: str
|
|
22
|
-
value: str
|
|
23
|
-
tone: str | None = None
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
class OrderActivity(BaseModel):
|
|
27
|
-
order_id: str
|
|
28
|
-
date: str
|
|
29
|
-
customer: str
|
|
30
|
-
status: str
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
class OrderDetail(BaseModel):
|
|
34
|
-
product_name: str
|
|
35
|
-
customer_name: str
|
|
36
|
-
status: str
|
|
37
|
-
amount: str
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
class OrderOverview(BaseModel):
|
|
41
|
-
stats: list[DashboardStat]
|
|
42
|
-
recent_activity: list[OrderActivity]
|
|
43
|
-
selected_order: OrderDetail
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
class OrderSummary(BaseModel):
|
|
47
|
-
id: str
|
|
48
|
-
product_name: str
|
|
49
|
-
customer_name: str
|
|
50
|
-
status: str
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
class StageStatus(BaseModel):
|
|
54
|
-
label: str
|
|
55
|
-
value: str
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
class AdminOrderOverview(BaseModel):
|
|
59
|
-
cards: list[DashboardStat]
|
|
60
|
-
stage_statuses: list[StageStatus]
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
class AdminQueueItem(BaseModel):
|
|
64
|
-
order_id: str
|
|
65
|
-
product_name: str
|
|
66
|
-
customer_name: str
|
|
67
|
-
status: str
|
|
68
|
-
sla: str
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
class CreateOrderCommand(BaseModel):
|
|
72
|
-
product_id: str
|
|
73
|
-
product_name: str
|
|
74
|
-
customer_name: str
|
|
75
|
-
seller_name: str
|
|
76
|
-
amount_krw: int
|
|
77
|
-
stage: str = "결제 대기"
|
|
78
|
-
status: str = "Pending"
|
|
79
|
-
fulfillment_status: str = "Queued"
|
|
80
|
-
sla: str = "55 min"
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
class UpdateOrderStatusCommand(BaseModel):
|
|
84
|
-
status: str
|
|
85
|
-
fulfillment_status: str | None = None
|
|
86
|
-
stage: str | None = None
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
class OrderStatusTransition(BaseModel):
|
|
90
|
-
id: str
|
|
91
|
-
previous_status: str
|
|
92
|
-
status: str
|
|
93
|
-
fulfillment_status: str
|
|
94
|
-
risk: str
|
|
95
|
-
stage: str
|
|
@@ -1,104 +0,0 @@
|
|
|
1
|
-
from datetime import date
|
|
2
|
-
|
|
3
|
-
from contexts.orders.domain import (
|
|
4
|
-
CreateOrderCommand,
|
|
5
|
-
OrderRecord,
|
|
6
|
-
OrderStatusTransition,
|
|
7
|
-
UpdateOrderStatusCommand,
|
|
8
|
-
)
|
|
9
|
-
from data.bootstrap_loader import load_bootstrap_json
|
|
10
|
-
|
|
11
|
-
_order_store: list[OrderRecord] | None = None
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
def _get_order_store() -> list[OrderRecord]:
|
|
15
|
-
global _order_store
|
|
16
|
-
if _order_store is None:
|
|
17
|
-
_order_store = [
|
|
18
|
-
OrderRecord(**entry) for entry in load_bootstrap_json("orders.json")
|
|
19
|
-
]
|
|
20
|
-
return _order_store
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
def _copy_orders(records: list[OrderRecord]) -> list[OrderRecord]:
|
|
24
|
-
return [record.model_copy(deep=True) for record in records]
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
def _next_order_number(records: list[OrderRecord]) -> int:
|
|
28
|
-
return max((int(record.id.split("-")[-1]) for record in records), default=24050) + 1
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
def _derive_fulfillment_status(status: str, current_status: str | None = None) -> str:
|
|
32
|
-
fulfillment_status_map = {
|
|
33
|
-
"Pending": "Queued",
|
|
34
|
-
"Paid": "Picking",
|
|
35
|
-
"At risk": "Exception",
|
|
36
|
-
"Completed": "Delivered",
|
|
37
|
-
"Cancelled": "Cancelled",
|
|
38
|
-
}
|
|
39
|
-
return fulfillment_status_map.get(status, current_status or "Queued")
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
def _derive_risk(status: str, current_risk: str | None = None) -> str:
|
|
43
|
-
if status == "At risk":
|
|
44
|
-
return "risk"
|
|
45
|
-
if status in {"Approved", "Completed"}:
|
|
46
|
-
return "ok"
|
|
47
|
-
return current_risk or "ok"
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
def list_seed_orders() -> list[OrderRecord]:
|
|
51
|
-
return _copy_orders(_get_order_store())
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
def create_seed_order(command: CreateOrderCommand) -> OrderRecord:
|
|
55
|
-
records = _get_order_store()
|
|
56
|
-
next_order_number = _next_order_number(records)
|
|
57
|
-
today = date.today().strftime("%Y.%m.%d")
|
|
58
|
-
record = OrderRecord(
|
|
59
|
-
id=f"ORD-{next_order_number:05d}",
|
|
60
|
-
product_id=command.product_id,
|
|
61
|
-
product_name=command.product_name,
|
|
62
|
-
customer_name=command.customer_name,
|
|
63
|
-
seller_name=command.seller_name,
|
|
64
|
-
status=command.status,
|
|
65
|
-
fulfillment_status=command.fulfillment_status,
|
|
66
|
-
created_at=today,
|
|
67
|
-
amount_krw=command.amount_krw,
|
|
68
|
-
risk=_derive_risk(command.status),
|
|
69
|
-
stage=command.stage,
|
|
70
|
-
sla=command.sla,
|
|
71
|
-
is_new_today=True,
|
|
72
|
-
)
|
|
73
|
-
records.insert(0, record)
|
|
74
|
-
return record.model_copy(deep=True)
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
def update_seed_order_status(
|
|
78
|
-
order_id: str, command: UpdateOrderStatusCommand
|
|
79
|
-
) -> OrderStatusTransition:
|
|
80
|
-
records = _get_order_store()
|
|
81
|
-
for index, record in enumerate(records):
|
|
82
|
-
if record.id != order_id:
|
|
83
|
-
continue
|
|
84
|
-
|
|
85
|
-
updated_record = record.model_copy(
|
|
86
|
-
update={
|
|
87
|
-
"status": command.status,
|
|
88
|
-
"fulfillment_status": command.fulfillment_status
|
|
89
|
-
or _derive_fulfillment_status(command.status, record.fulfillment_status),
|
|
90
|
-
"risk": _derive_risk(command.status, record.risk),
|
|
91
|
-
"stage": command.stage or record.stage,
|
|
92
|
-
}
|
|
93
|
-
)
|
|
94
|
-
records[index] = updated_record
|
|
95
|
-
return OrderStatusTransition(
|
|
96
|
-
id=updated_record.id,
|
|
97
|
-
previous_status=record.status,
|
|
98
|
-
status=updated_record.status,
|
|
99
|
-
fulfillment_status=updated_record.fulfillment_status,
|
|
100
|
-
risk=updated_record.risk,
|
|
101
|
-
stage=updated_record.stage,
|
|
102
|
-
)
|
|
103
|
-
|
|
104
|
-
raise LookupError(f"Order {order_id} not found")
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
__all__ = ["application", "contracts", "domain", "infrastructure"]
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
from .services import (
|
|
2
|
-
get_shipment_list,
|
|
3
|
-
get_shipping_overview,
|
|
4
|
-
prepare_shipping_store,
|
|
5
|
-
transition_shipment_status,
|
|
6
|
-
)
|
|
7
|
-
|
|
8
|
-
__all__ = [
|
|
9
|
-
"get_shipment_list",
|
|
10
|
-
"get_shipping_overview",
|
|
11
|
-
"prepare_shipping_store",
|
|
12
|
-
"transition_shipment_status",
|
|
13
|
-
]
|
|
@@ -1,92 +0,0 @@
|
|
|
1
|
-
from contexts.shipping.domain import (
|
|
2
|
-
ShippingCarrierLoad,
|
|
3
|
-
ShippingOverview,
|
|
4
|
-
ShippingStat,
|
|
5
|
-
ShipmentStatusTransition,
|
|
6
|
-
ShipmentSummary,
|
|
7
|
-
UpdateShipmentStatusCommand,
|
|
8
|
-
)
|
|
9
|
-
from contexts.shipping.infrastructure import (
|
|
10
|
-
list_seed_shipments,
|
|
11
|
-
transition_seed_shipment_status,
|
|
12
|
-
)
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
def get_shipping_overview() -> ShippingOverview:
|
|
16
|
-
records = list_seed_shipments()
|
|
17
|
-
in_transit_count = sum(
|
|
18
|
-
1
|
|
19
|
-
for record in records
|
|
20
|
-
if record.status in {"In transit", "Out for delivery", "Delayed"}
|
|
21
|
-
)
|
|
22
|
-
delayed_count = sum(1 for record in records if record.status == "Delayed")
|
|
23
|
-
delivered_today_count = sum(1 for record in records if record.delivered_today)
|
|
24
|
-
|
|
25
|
-
carrier_names = sorted({record.carrier for record in records})
|
|
26
|
-
carriers = []
|
|
27
|
-
for carrier in carrier_names:
|
|
28
|
-
carrier_records = [record for record in records if record.carrier == carrier]
|
|
29
|
-
delayed_for_carrier = sum(
|
|
30
|
-
1 for record in carrier_records if record.status == "Delayed"
|
|
31
|
-
)
|
|
32
|
-
carriers.append(
|
|
33
|
-
ShippingCarrierLoad(
|
|
34
|
-
label=carrier,
|
|
35
|
-
value=f"{len(carrier_records)}건 · 지연 {delayed_for_carrier}건",
|
|
36
|
-
)
|
|
37
|
-
)
|
|
38
|
-
|
|
39
|
-
highlighted = next(
|
|
40
|
-
(record for record in records if record.status == "Delayed"),
|
|
41
|
-
records[0],
|
|
42
|
-
)
|
|
43
|
-
|
|
44
|
-
return ShippingOverview(
|
|
45
|
-
stats=[
|
|
46
|
-
ShippingStat(
|
|
47
|
-
label="배송 중",
|
|
48
|
-
value=str(in_transit_count),
|
|
49
|
-
tone="text-[var(--in-accent)]",
|
|
50
|
-
),
|
|
51
|
-
ShippingStat(
|
|
52
|
-
label="지연",
|
|
53
|
-
value=str(delayed_count),
|
|
54
|
-
tone="text-[#c4663a]",
|
|
55
|
-
),
|
|
56
|
-
ShippingStat(
|
|
57
|
-
label="오늘 완료",
|
|
58
|
-
value=str(delivered_today_count),
|
|
59
|
-
tone="text-[#245f92]",
|
|
60
|
-
),
|
|
61
|
-
],
|
|
62
|
-
carriers=carriers,
|
|
63
|
-
highlighted_route=(
|
|
64
|
-
f"{highlighted.route_name} · {highlighted.last_event}"
|
|
65
|
-
),
|
|
66
|
-
)
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
def get_shipment_list() -> list[ShipmentSummary]:
|
|
70
|
-
return [
|
|
71
|
-
ShipmentSummary(
|
|
72
|
-
shipment_id=record.shipment_id,
|
|
73
|
-
order_id=record.order_id,
|
|
74
|
-
carrier=record.carrier,
|
|
75
|
-
destination=record.destination,
|
|
76
|
-
tracking_number=record.tracking_number,
|
|
77
|
-
status=record.status,
|
|
78
|
-
eta=record.eta,
|
|
79
|
-
last_event=record.last_event,
|
|
80
|
-
)
|
|
81
|
-
for record in list_seed_shipments()
|
|
82
|
-
]
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
def transition_shipment_status(
|
|
86
|
-
shipment_id: str, command: UpdateShipmentStatusCommand
|
|
87
|
-
) -> ShipmentStatusTransition:
|
|
88
|
-
return transition_seed_shipment_status(shipment_id, command)
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
def prepare_shipping_store() -> None:
|
|
92
|
-
list_seed_shipments()
|
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
from fastapi import APIRouter, Depends, HTTPException
|
|
2
|
-
|
|
3
|
-
from contexts.auth.contracts.http.dependencies import require_authenticated_user
|
|
4
|
-
from contexts.shipping.application import (
|
|
5
|
-
get_shipment_list,
|
|
6
|
-
get_shipping_overview,
|
|
7
|
-
transition_shipment_status,
|
|
8
|
-
)
|
|
9
|
-
from contexts.shipping.domain import (
|
|
10
|
-
ShippingOverview,
|
|
11
|
-
ShipmentStatusTransition,
|
|
12
|
-
ShipmentSummary,
|
|
13
|
-
UpdateShipmentStatusCommand,
|
|
14
|
-
)
|
|
15
|
-
|
|
16
|
-
router = APIRouter(
|
|
17
|
-
prefix="/shipping",
|
|
18
|
-
tags=["shipping"],
|
|
19
|
-
dependencies=[Depends(require_authenticated_user)],
|
|
20
|
-
)
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
@router.get("/overview", response_model=ShippingOverview)
|
|
24
|
-
def shipping_overview() -> ShippingOverview:
|
|
25
|
-
return get_shipping_overview()
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
@router.get("/shipments", response_model=list[ShipmentSummary])
|
|
29
|
-
def list_shipments() -> list[ShipmentSummary]:
|
|
30
|
-
return get_shipment_list()
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
@router.patch("/shipments/{shipment_id}/status", response_model=ShipmentStatusTransition)
|
|
34
|
-
def patch_shipment_status(
|
|
35
|
-
shipment_id: str, command: UpdateShipmentStatusCommand
|
|
36
|
-
) -> ShipmentStatusTransition:
|
|
37
|
-
try:
|
|
38
|
-
return transition_shipment_status(shipment_id, command)
|
|
39
|
-
except LookupError as exc:
|
|
40
|
-
raise HTTPException(status_code=404, detail=str(exc)) from exc
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
from .models import (
|
|
2
|
-
ShippingCarrierLoad,
|
|
3
|
-
ShippingOverview,
|
|
4
|
-
ShippingStat,
|
|
5
|
-
ShipmentRecord,
|
|
6
|
-
ShipmentStatusTransition,
|
|
7
|
-
ShipmentSummary,
|
|
8
|
-
UpdateShipmentStatusCommand,
|
|
9
|
-
)
|
|
10
|
-
|
|
11
|
-
__all__ = [
|
|
12
|
-
"ShippingCarrierLoad",
|
|
13
|
-
"ShippingOverview",
|
|
14
|
-
"ShippingStat",
|
|
15
|
-
"ShipmentRecord",
|
|
16
|
-
"ShipmentStatusTransition",
|
|
17
|
-
"ShipmentSummary",
|
|
18
|
-
"UpdateShipmentStatusCommand",
|
|
19
|
-
]
|
|
@@ -1,48 +0,0 @@
|
|
|
1
|
-
from pydantic import BaseModel
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
class ShippingStat(BaseModel):
|
|
5
|
-
label: str
|
|
6
|
-
value: str
|
|
7
|
-
tone: str | None = None
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
class ShippingCarrierLoad(BaseModel):
|
|
11
|
-
label: str
|
|
12
|
-
value: str
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
class ShippingOverview(BaseModel):
|
|
16
|
-
stats: list[ShippingStat]
|
|
17
|
-
carriers: list[ShippingCarrierLoad]
|
|
18
|
-
highlighted_route: str
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
class ShipmentSummary(BaseModel):
|
|
22
|
-
shipment_id: str
|
|
23
|
-
order_id: str
|
|
24
|
-
carrier: str
|
|
25
|
-
destination: str
|
|
26
|
-
tracking_number: str
|
|
27
|
-
status: str
|
|
28
|
-
eta: str
|
|
29
|
-
last_event: str
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
class ShipmentRecord(ShipmentSummary):
|
|
33
|
-
route_name: str
|
|
34
|
-
delivered_today: bool
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
class UpdateShipmentStatusCommand(BaseModel):
|
|
38
|
-
status: str
|
|
39
|
-
last_event: str
|
|
40
|
-
eta: str | None = None
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
class ShipmentStatusTransition(BaseModel):
|
|
44
|
-
shipment_id: str
|
|
45
|
-
previous_status: str
|
|
46
|
-
status: str
|
|
47
|
-
previous_last_event: str
|
|
48
|
-
last_event: str
|
|
@@ -1,50 +0,0 @@
|
|
|
1
|
-
from contexts.shipping.domain import (
|
|
2
|
-
ShipmentRecord,
|
|
3
|
-
ShipmentStatusTransition,
|
|
4
|
-
UpdateShipmentStatusCommand,
|
|
5
|
-
)
|
|
6
|
-
from data.bootstrap_loader import load_bootstrap_json
|
|
7
|
-
|
|
8
|
-
_shipment_store: list[ShipmentRecord] | None = None
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
def _get_shipment_store() -> list[ShipmentRecord]:
|
|
12
|
-
global _shipment_store
|
|
13
|
-
if _shipment_store is None:
|
|
14
|
-
_shipment_store = [
|
|
15
|
-
ShipmentRecord(**entry)
|
|
16
|
-
for entry in load_bootstrap_json("shipping_shipments.json")
|
|
17
|
-
]
|
|
18
|
-
return _shipment_store
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
def list_seed_shipments() -> list[ShipmentRecord]:
|
|
22
|
-
return [record.model_copy(deep=True) for record in _get_shipment_store()]
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
def transition_seed_shipment_status(
|
|
26
|
-
shipment_id: str, command: UpdateShipmentStatusCommand
|
|
27
|
-
) -> ShipmentStatusTransition:
|
|
28
|
-
records = _get_shipment_store()
|
|
29
|
-
for index, record in enumerate(records):
|
|
30
|
-
if record.shipment_id != shipment_id:
|
|
31
|
-
continue
|
|
32
|
-
|
|
33
|
-
updated_record = record.model_copy(
|
|
34
|
-
update={
|
|
35
|
-
"status": command.status,
|
|
36
|
-
"last_event": command.last_event,
|
|
37
|
-
"eta": command.eta or record.eta,
|
|
38
|
-
"delivered_today": command.status == "Delivered",
|
|
39
|
-
}
|
|
40
|
-
)
|
|
41
|
-
records[index] = updated_record
|
|
42
|
-
return ShipmentStatusTransition(
|
|
43
|
-
shipment_id=updated_record.shipment_id,
|
|
44
|
-
previous_status=record.status,
|
|
45
|
-
status=updated_record.status,
|
|
46
|
-
previous_last_event=record.last_event,
|
|
47
|
-
last_event=updated_record.last_event,
|
|
48
|
-
)
|
|
49
|
-
|
|
50
|
-
raise LookupError(f"Shipment {shipment_id} not found")
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
__all__ = ["application", "contracts", "domain", "infrastructure"]
|
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
from contexts.support.domain import (
|
|
2
|
-
ChangeFaqVisibilityCommand,
|
|
3
|
-
CreateSupportFaqCommand,
|
|
4
|
-
SupportFaq,
|
|
5
|
-
SupportFaqRecord,
|
|
6
|
-
)
|
|
7
|
-
from contexts.support.infrastructure import (
|
|
8
|
-
create_seed_support_faq,
|
|
9
|
-
list_seed_support_faqs,
|
|
10
|
-
update_seed_support_faq_visibility,
|
|
11
|
-
)
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
def get_support_faqs() -> list[SupportFaq]:
|
|
15
|
-
return list_seed_support_faqs()
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
def create_support_faq(command: CreateSupportFaqCommand) -> SupportFaqRecord:
|
|
19
|
-
return create_seed_support_faq(command)
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
def change_faq_visibility(
|
|
23
|
-
faq_id: str, command: ChangeFaqVisibilityCommand
|
|
24
|
-
) -> SupportFaqRecord:
|
|
25
|
-
return update_seed_support_faq_visibility(faq_id, command)
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
def prepare_support_store() -> None:
|
|
29
|
-
list_seed_support_faqs()
|