Files
ewoooc/routes
OoO 3c0e558fbe
All checks were successful
CD Pipeline / deploy (push) Successful in 1m3s
V10.622 refresh growth cache after offer sync
2026-06-16 11:49:06 +08:00
..
2026-05-19 15:53:09 +08:00
2026-05-14 00:57:29 +08:00
2026-05-14 00:57:29 +08:00

路由模組說明

app.py 直接註冊所有 Flask BlueprintUSE_MODULAR_ROUTESregister_blueprints()MODULAR_ENDPOINTS 與 duplicate cleanup 開關已在 ADR-017 Phase 3f-1 移除。

啟動防線

app.py 會在啟動時檢查 app.url_map,同一組 (URL, HTTP methods) 不允許被兩個 endpoint 重複註冊;若發現衝突會直接 SystemExit

模組清單

模組 說明 主要路由
dashboard_routes.py 商品看板首頁 /
sales_routes.py 業績分析與 ABC 明細 /sales_analysis, /growth_analysis, /abc_analysis/detail, /api/sales_analysis/*
system_public_routes.py 無 prefix 公開系統頁與監控 /health, /metrics, /ai_automation_smoke, /api/ai-automation/smoke*, /settings, /system_settings, /logs, /api/logs, /api/backup
system_routes.py 內部系統維護 API /api/system/*
edm_routes.py EDM 與節慶儀表板 /edm, /festival
monthly_routes.py 月結分析 /monthly_summary_analysis, /api/monthly_summary_data
daily_sales_routes.py 當日業績 /daily_sales, /daily_sales/export*
market_intel_routes.py 市場情報 Phase 104 主路由與基礎 preview API /market_intel, /market_intel/*, /api/market_intel/status, /api/market_intel/schema, /api/market_intel/schema_smoke, /api/market_intel/schema_db_probe, /api/market_intel/platform_seed_db_diff, /api/market_intel/legacy_source_bridge, /api/market_intel/mcp_readiness, /api/market_intel/mcp_tool_contract, /api/market_intel/mcp_deploy_preflight, /api/market_intel/mcp_activation_runbook, /api/market_intel/mcp_fetch_gate, /api/market_intel/scheduler_plan, /api/market_intel/manual_sample_plan, /api/market_intel/manual_sample_acceptance, /api/market_intel/manual_sample_review, /api/market_intel/manual_sample_review/evaluate, /api/market_intel/manual_sample_review/candidate_handoff, /api/market_intel/manual_sample_review/candidate_queue_draft, /api/market_intel/manual_sample_review/candidate_queue_approval, /api/market_intel/manual_sample_review/candidate_queue_transaction, /api/market_intel/manual_sample_review/candidate_queue_writer_status, /api/market_intel/manual_sample_review/candidate_queue_writer_preflight, /api/market_intel/manual_sample_review/candidate_queue_writer_postwrite_smoke, /api/market_intel/manual_sample_review/candidate_queue_writer_operator_drill, /api/market_intel/manual_sample_review/candidate_queue_writer_run_package, /api/market_intel/manual_sample_review/candidate_queue_writer_run_readiness, /api/market_intel/manual_sample_review/candidate_queue_writer_run_receipt, /api/market_intel/manual_sample_review/candidate_queue_writer_run_closeout, /api/market_intel/manual_sample_review/candidate_queue_review_handoff, /api/market_intel/match_review_plan, /api/market_intel/opportunity_plan, /api/market_intel/opportunity_scoring_plan, /api/market_intel/opportunity_evidence_plan, /api/market_intel/opportunity_alert_plan, /api/market_intel/adapters, /api/market_intel/dry_run_plan, /api/market_intel/discovery_plan, /api/market_intel/manual_discovery, /api/market_intel/candidate_preview, /api/market_intel/platform_seed_plan, /api/market_intel/platform_seed_write_guard, /api/market_intel/platform_seed_writer_plan, /api/market_intel/migration_blueprint, /api/market_intel/migration_apply_drill, /api/market_intel/migration_catalog_review, /api/market_intel/migration_live_smoke, /api/market_intel/live_db_inventory, /api/market_intel/seed_writer_cli_status, /api/market_intel/write_approval_runbook, /api/market_intel/deployment_readiness
market_intel_review_routes.py 市場情報人工 queue review 只讀延伸 API /api/market_intel/manual_sample_review/candidate_queue_review_inventory, /api/market_intel/manual_sample_review/candidate_queue_review_decision, /api/market_intel/manual_sample_review/candidate_queue_review_decision_approval, /api/market_intel/manual_sample_review/candidate_queue_review_decision_transaction, /api/market_intel/manual_sample_review/candidate_queue_review_decision_writer_status, /api/market_intel/manual_sample_review/candidate_queue_review_decision_writer_preflight, /api/market_intel/manual_sample_review/candidate_queue_review_decision_writer_postwrite_smoke, /api/market_intel/manual_sample_review/candidate_queue_review_decision_writer_operator_drill, /api/market_intel/manual_sample_review/candidate_queue_review_decision_writer_run_package, /api/market_intel/manual_sample_review/candidate_queue_review_decision_writer_run_readiness, /api/market_intel/manual_sample_review/candidate_queue_review_decision_writer_run_receipt, /api/market_intel/manual_sample_review/candidate_queue_review_decision_writer_run_closeout
market_intel_review_post_routes.py 市場情報 review_state closeout 後只讀延伸 API掛在 market_intel_review_bp /api/market_intel/manual_sample_review/candidate_queue_review_decision_post_closeout_inventory, /api/market_intel/manual_sample_review/candidate_queue_review_completion_archive, /api/market_intel/manual_sample_review/candidate_queue_review_archive_summary, /api/market_intel/manual_sample_review/candidate_queue_review_ai_summary_preflight, /api/market_intel/manual_sample_review/candidate_queue_review_ai_summary_run_package, /api/market_intel/manual_sample_review/candidate_queue_review_ai_summary_output_receipt, /api/market_intel/manual_sample_review/candidate_queue_review_ai_summary_persistence_preflight, /api/market_intel/manual_sample_review/candidate_queue_review_ai_summary_persistence_transaction, /api/market_intel/manual_sample_review/candidate_queue_review_ai_summary_persistence_writer_preflight, /api/market_intel/manual_sample_review/candidate_queue_review_ai_summary_persistence_run_package
market_intel_review_post_ai_routes.py 市場情報 AI summary persistence / Telegram dispatch 後續只讀延伸 API掛在 market_intel_review_bp /api/market_intel/manual_sample_review/candidate_queue_review_ai_summary_persistence_run_readiness, /api/market_intel/manual_sample_review/candidate_queue_review_ai_summary_persistence_run_receipt, /api/market_intel/manual_sample_review/candidate_queue_review_ai_summary_persistence_run_closeout, /api/market_intel/manual_sample_review/candidate_queue_review_ai_summary_persistence_telegram_dispatch_gate, /api/market_intel/manual_sample_review/candidate_queue_review_ai_summary_persistence_telegram_dispatch_run_package, /api/market_intel/manual_sample_review/candidate_queue_review_ai_summary_persistence_telegram_dispatch_run_readiness, /api/market_intel/manual_sample_review/candidate_queue_review_ai_summary_persistence_telegram_dispatch_run_receipt, /api/market_intel/manual_sample_review/candidate_queue_review_ai_summary_persistence_telegram_dispatch_closeout, /api/market_intel/manual_sample_review/candidate_queue_review_ai_summary_persistence_telegram_dispatch_archive, /api/market_intel/manual_sample_review/candidate_queue_review_ai_summary_persistence_telegram_dispatch_archive_summary
market_intel_review_report_routes.py 市場情報 report input / report run package / report run readiness / report run receipt / report closeout / report archive / report catalog handoff 後續只讀延伸 API掛在 market_intel_review_bp /api/market_intel/manual_sample_review/candidate_queue_review_ai_summary_persistence_telegram_dispatch_report_input, /api/market_intel/manual_sample_review/candidate_queue_review_ai_summary_persistence_telegram_dispatch_report_run_package, /api/market_intel/manual_sample_review/candidate_queue_review_ai_summary_persistence_telegram_dispatch_report_run_readiness, /api/market_intel/manual_sample_review/candidate_queue_review_ai_summary_persistence_telegram_dispatch_report_run_receipt, /api/market_intel/manual_sample_review/candidate_queue_review_ai_summary_persistence_telegram_dispatch_report_closeout, /api/market_intel/manual_sample_review/candidate_queue_review_ai_summary_persistence_telegram_dispatch_report_archive, /api/market_intel/manual_sample_review/candidate_queue_review_ai_summary_persistence_telegram_dispatch_report_archive_summary, /api/market_intel/manual_sample_review/candidate_queue_review_ai_summary_persistence_telegram_dispatch_report_catalog_handoff
api_routes.py 通用任務與查詢 API /api/run_task, /api/history/*
ai_routes.py AI 推薦、競情儀表板與 PChome 成長作戰 API /ai_recommend, /ai_intelligence, /api/ai/status, /api/ai/icaim/dashboard, /api/ai/pchome-growth/opportunities, /api/ai/pchome-growth/source-contract, /api/ai/pchome-growth/external-offers/csv-dry-run
export_routes.py 匯出功能 /api/export/*
import_routes.py 匯入功能 /api/import_excel, /api/import/monthly_summary

新增 route 時請優先放入對應 Blueprint並用本機 app.url_map duplicate check 驗證。 若 route 內開始出現大量資料處理、SQL、AI prompt 或外部 API 呼叫,請依 docs/guides/modularization_governance.md 抽到 services/utils/,不要讓 Blueprint 變成新巨檔。