import { Worker, type Job } from 'bullmq'; import type { ConnectionOptions } from 'bullmq'; import { logger } from '@/lib/logger'; import { QUEUE_CONFIGS } from '@/lib/queue'; export const bulkWorker = new Worker( 'bulk', async (job: Job) => { logger.info({ jobId: job.id, jobName: job.name }, 'Processing bulk job'); // TODO(L2): implement bulk operation job handlers // - bulk status change across multiple records // - bulk tag assignment / removal // - bulk delete with soft-delete support }, { connection: { url: process.env.REDIS_URL! } as ConnectionOptions, concurrency: QUEUE_CONFIGS.bulk.concurrency, }, ); bulkWorker.on('failed', (job, err) => { logger.error({ jobId: job?.id, jobName: job?.name, err }, 'Bulk job failed'); });