routers: extract chat + ops from api.py
api.py was 933 lines mixing four distinct concerns: indicators + news + strategic log (the JSON/HTMX API proper), the chat endpoint + its three private helpers (~200 lines), and the two HTML-only ops endpoints /markets-bar + /health (~150 lines). Extracted: - app/routers/chat.py — POST /api/chat + _latest_quotes_by_group_chat, _thesis_headlines_for_chat, _month_spend - app/routers/ops.py — GET /api/markets-bar + GET /api/health + _fmt_price helper Both new routers use the same dependencies=[Depends(require_token)] as api.py and are mounted at the /api prefix in app/main.py. URL surface is byte-identical with no externally-visible change. api.py shrinks to ~620 lines focused on indicators+news+log+settings. Helpers shared with the original api.py (_md_to_html, _resolve_tone_param) are imported from app.routers.api where needed in chat.py to avoid duplication. Also updated tests/test_chat_and_log_gates.py to mount chat_router in its local test app, since /api/chat now lives there. Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
This commit is contained in:
parent
b055eea1c2
commit
833d1775ab
5 changed files with 364 additions and 322 deletions
|
|
@ -19,7 +19,9 @@ from app.db import get_session_factory
|
|||
from app.logging import configure_logging, get_logger
|
||||
from app.routers import api as api_router
|
||||
from app.routers import auth as auth_router
|
||||
from app.routers import chat as chat_router
|
||||
from app.routers import email as email_router
|
||||
from app.routers import ops as ops_router
|
||||
from app.routers import pages as pages_router
|
||||
from app.routers import polar_webhook as polar_webhook_router
|
||||
from app.routers import public as public_router
|
||||
|
|
@ -89,6 +91,8 @@ app.mount(
|
|||
app.include_router(auth_router.router, tags=["auth"])
|
||||
app.include_router(email_router.router, tags=["email"])
|
||||
app.include_router(api_router.router, prefix="/api", tags=["api"])
|
||||
app.include_router(chat_router.router, prefix="/api", tags=["chat"])
|
||||
app.include_router(ops_router.router, prefix="/api", tags=["ops"])
|
||||
app.include_router(universe_router.router, prefix="/api", tags=["universe"])
|
||||
app.include_router(ticker_validate_router.router, prefix="/api", tags=["ticker-validate"])
|
||||
app.include_router(sync_router.router, tags=["portfolio-sync"])
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue