Files
home_hub/backend/app/core/redis.py
T
gilles be0c8bceb6 feat: export Markdown notes (ARQ/Redis) + backup/restore BDD — v0.5.2
- Volume data/ (bind mount ./data) remplace le volume uploads nommé
  data/notes/ → .md auto-générés, data/uploads/ → médias, data/backup/ → dumps
- Service Redis (redis:7-alpine) + worker ARQ (backend-worker)
- notes_markdown.py : frontmatter YAML + contenu + pièces jointes (liens relatifs)
  Nom : YYYY-MM-DD_slug-titre_shortid.md, rotation si titre modifié
- api/notes.py : publie export_note_markdown / remove_note_markdown sur Redis
  après chaque create / update / delete / add_attachment / delete_attachment
- api/admin.py : POST /backup, GET /backups, POST /restore/{filename} (pg_dump/pg_restore)
- Backend Dockerfile : postgresql-client ; requirements : arq==0.26.1
- ConfigPage : section "Base de données" avec sauvegarde + liste + restauration

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-05-25 15:33:29 +02:00

34 lines
850 B
Python

import logging
from arq import create_pool
from arq.connections import ArqRedis, RedisSettings
from app.core.config import settings
_pool: ArqRedis | None = None
logger = logging.getLogger(__name__)
async def init_redis() -> None:
global _pool
try:
_pool = await create_pool(RedisSettings.from_dsn(settings.redis_url))
logger.info("Redis pool initialisé")
except Exception as e:
logger.warning(f"Redis indisponible, export Markdown désactivé : {e}")
async def close_redis() -> None:
global _pool
if _pool:
await _pool.close()
_pool = None
async def enqueue(job_name: str, *args) -> None:
if _pool is None:
return
try:
await _pool.enqueue_job(job_name, *args)
except Exception as e:
logger.warning(f"Redis enqueue échoué ({job_name}) : {e}")