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.
30 lines
916 B
TypeScript
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,
|
|
}
|