- telegram_alerts.py: service envoi alertes via Bot API (send_pre_race_alerts,
build_race_alert, send_telegram_message) — gestion gracieuse TELEGRAM_BOT_TOKEN absent
- auth_db.py: migrate_telegram_columns() idempotente (ALTER TABLE + try/except OperationalError)
colonnes: telegram_chat_id, alert_value_bets, alert_top1, alert_quinte_only
- api_v1/routes/user.py: blueprint user_bp GET/POST /api/v1/user/telegram-config
protégé @jwt_required_middleware + @plan_required('premium','pro')
- api_v1/__init__.py: import + register user_bp
- turf_scheduler.py: run_telegram_alerts() + schedule_dynamic_telegram_alerts()
planifiées 30min avant course (même pattern que schedule_dynamic_scoring)
avec try/except Exception + fallback logger
Co-Authored-By: Paperclip <noreply@paperclip.ing>
48 lines
1.7 KiB
Python
48 lines
1.7 KiB
Python
#!/usr/bin/env python3
|
|
"""
|
|
API v1 Blueprint package — Turf SaaS
|
|
Sprint 3-4: HRT-29 — Refacto API /v1/
|
|
Sprint 5-6: HRT-31 — Billing Stripe
|
|
HRT-79: Alertes Telegram configurables (user blueprint)
|
|
|
|
Registers sub-blueprints:
|
|
/api/v1/health — public health-check
|
|
/api/v1/courses/ — courses du jour
|
|
/api/v1/predictions/— predictions ML
|
|
/api/v1/valuebets — value bets (premium+)
|
|
/api/v1/backtest — backtest historique (pro)
|
|
/api/v1/export/ — export CSV (pro)
|
|
/api/v1/metrics — métriques perf ML (premium+)
|
|
/api/v1/billing/ — Stripe checkout, portal, webhook, status
|
|
/api/v1/user/ — config utilisateur, alertes Telegram (premium+)
|
|
/api/v1/docs — Swagger UI (via flasgger, registered on app)
|
|
"""
|
|
|
|
from flask import Blueprint
|
|
|
|
from .routes.health import health_bp
|
|
from .routes.courses import courses_bp
|
|
from .routes.predictions import predictions_bp
|
|
from .routes.valuebets import valuebets_bp
|
|
from .routes.backtest import backtest_bp
|
|
from .routes.export import export_bp
|
|
from .routes.metrics import metrics_bp
|
|
from .routes.billing import billing_bp
|
|
from .routes.user import user_bp
|
|
|
|
# Master blueprint that aggregates all sub-routes under /api/v1
|
|
api_v1_bp = Blueprint("api_v1", __name__, url_prefix="/api/v1")
|
|
|
|
|
|
def register_api_v1(app):
|
|
"""Register all API v1 blueprints onto the Flask app."""
|
|
app.register_blueprint(health_bp)
|
|
app.register_blueprint(courses_bp)
|
|
app.register_blueprint(predictions_bp)
|
|
app.register_blueprint(valuebets_bp)
|
|
app.register_blueprint(backtest_bp)
|
|
app.register_blueprint(export_bp)
|
|
app.register_blueprint(metrics_bp)
|
|
app.register_blueprint(billing_bp)
|
|
app.register_blueprint(user_bp)
|