- Fetch bill actions from Congress.gov and populate the action timeline - Add nightly batch task and beat schedule for active bill actions - Add admin reprocess endpoint for per-bill debugging - Add BriefPanel with "What Changed" view and version history - Add External API Health section with per-source latency testing - Redesign Manual Controls as health panel with status dots and descriptions - Add Resume Analysis task for stalled LLM jobs - Add Backfill Dates & Links task for bills with null metadata - Fix LLM provider/model DB overrides being ignored (env vars used instead) - Fix Gemini 404: gemini-1.5-pro deprecated → gemini-2.0-flash - Fix Anthropic models list: use REST API directly (SDK too old for .models) - Replace test-LLM full analysis with lightweight ping (max_tokens=20) - Add has_document field to BillDetail; show "No bill text published" state - Fix "Introduced: —" showing for bills with null introduced_date - Add bills_missing_sponsor and bills_missing_metadata to admin stats - Add GovInfo health check using /collections endpoint (fixes 500 from /packages) Authored-By: Jack Levy
83 lines
3.1 KiB
Python
83 lines
3.1 KiB
Python
from celery import Celery
|
|
from celery.schedules import crontab
|
|
from kombu import Queue
|
|
|
|
from app.config import settings
|
|
|
|
celery_app = Celery(
|
|
"pocketveto",
|
|
broker=settings.REDIS_URL,
|
|
backend=settings.REDIS_URL,
|
|
include=[
|
|
"app.workers.congress_poller",
|
|
"app.workers.document_fetcher",
|
|
"app.workers.llm_processor",
|
|
"app.workers.news_fetcher",
|
|
"app.workers.trend_scorer",
|
|
"app.workers.member_interest",
|
|
"app.workers.notification_dispatcher",
|
|
],
|
|
)
|
|
|
|
celery_app.conf.update(
|
|
task_serializer="json",
|
|
result_serializer="json",
|
|
accept_content=["json"],
|
|
timezone="UTC",
|
|
enable_utc=True,
|
|
# Late ack: task is only removed from queue after completion, not on pickup.
|
|
# Combined with idempotent tasks, this ensures no work is lost if a worker crashes.
|
|
task_acks_late=True,
|
|
# Prevent workers from prefetching LLM tasks and blocking other workers.
|
|
worker_prefetch_multiplier=1,
|
|
# Route tasks to named queues
|
|
task_routes={
|
|
"app.workers.congress_poller.*": {"queue": "polling"},
|
|
"app.workers.document_fetcher.*": {"queue": "documents"},
|
|
"app.workers.llm_processor.*": {"queue": "llm"},
|
|
"app.workers.news_fetcher.*": {"queue": "news"},
|
|
"app.workers.trend_scorer.*": {"queue": "news"},
|
|
"app.workers.member_interest.*": {"queue": "news"},
|
|
"app.workers.notification_dispatcher.*": {"queue": "polling"},
|
|
},
|
|
task_queues=[
|
|
Queue("polling"),
|
|
Queue("documents"),
|
|
Queue("llm"),
|
|
Queue("news"),
|
|
],
|
|
# RedBeat stores schedule in Redis — restart-safe and dynamically updatable
|
|
redbeat_redis_url=settings.REDIS_URL,
|
|
beat_scheduler="redbeat.RedBeatScheduler",
|
|
beat_schedule={
|
|
"poll-congress-bills": {
|
|
"task": "app.workers.congress_poller.poll_congress_bills",
|
|
"schedule": crontab(minute=f"*/{settings.CONGRESS_POLL_INTERVAL_MINUTES}"),
|
|
},
|
|
"fetch-news-active-bills": {
|
|
"task": "app.workers.news_fetcher.fetch_news_for_active_bills",
|
|
"schedule": crontab(hour="*/6", minute=0),
|
|
},
|
|
"calculate-trend-scores": {
|
|
"task": "app.workers.trend_scorer.calculate_all_trend_scores",
|
|
"schedule": crontab(hour=2, minute=0),
|
|
},
|
|
"fetch-news-active-members": {
|
|
"task": "app.workers.member_interest.fetch_news_for_active_members",
|
|
"schedule": crontab(hour="*/12", minute=30),
|
|
},
|
|
"calculate-member-trend-scores": {
|
|
"task": "app.workers.member_interest.calculate_all_member_trend_scores",
|
|
"schedule": crontab(hour=3, minute=0),
|
|
},
|
|
"fetch-actions-active-bills": {
|
|
"task": "app.workers.congress_poller.fetch_actions_for_active_bills",
|
|
"schedule": crontab(hour=4, minute=0), # 4 AM UTC, after trend + member scoring
|
|
},
|
|
"dispatch-notifications": {
|
|
"task": "app.workers.notification_dispatcher.dispatch_notifications",
|
|
"schedule": crontab(minute="*/5"), # Every 5 minutes
|
|
},
|
|
},
|
|
)
|