rubis/apps/api/config/queue.ts
ordinarthur 274f2a8270 feat(api): install + configure bouncer, mail, limiter, drive, bullmq
Stack backend complète selon docs/tech/backend.md §2 :

- @adonisjs/bouncer : configure standard, middleware initialize_bouncer simplifié (API JSON-only, pas d'Edge views).
- @adonisjs/limiter : store Redis par défaut, throttler global défini dans start/limiter.ts.
- @adonisjs/mail : transports SMTP (Mailpit en dev) + Resend (prod).
- @adonisjs/drive : services fs (fallback) + S3 (MinIO en dev, prod plus tard).
- bullmq + ioredis : config queue.ts définit la connection Redis et la liste des queues (ocr, relances, checkins, kpis). Worker à câbler dans le commit suivant.
- @aws-sdk/client-s3 + s3-request-presigner pour le driver flydrive S3.

Pas de @rlanz/bull-queue : peer Adonis 6.5, plus maintenu — on consomme BullMQ directement.
2026-05-06 13:25:00 +02:00

30 lines
916 B
TypeScript

import env from '#start/env'
import { type RedisOptions } from 'ioredis'
/**
* Connexion Redis partagée pour BullMQ. On garde un objet d'options
* (et pas une instance) parce que BullMQ instancie ses propres clients
* pour chaque queue/worker.
*/
export const redisConnection: RedisOptions = {
host: env.get('REDIS_HOST', 'localhost'),
port: env.get('REDIS_PORT', 6379),
password: env.get('REDIS_PASSWORD') || undefined,
// Requis par BullMQ pour les blocking commands.
maxRetriesPerRequest: null,
}
/**
* Liste des queues. La concurrence est appliquée côté worker.
* Ajouter une queue ici → ajouter un Worker correspondant dans #start/queue.ts.
*/
export const queueNames = ['ocr', 'relances', 'checkins', 'kpis'] as const
export type QueueName = (typeof queueNames)[number]
export const queueConcurrency: Record<QueueName, number> = {
ocr: 2,
relances: 5,
checkins: 5,
kpis: 1,
}