collect-system/apps/server/src/queue/worker/file.processor.ts

26 lines
1.0 KiB
TypeScript

import { Job } from 'bullmq';
import { Logger } from '@nestjs/common';
import { QueueJobType } from '../types';
import { ResourceProcessingPipeline } from '@server/models/resource/pipe/resource.pipeline';
import { GeneralProcessor } from '@server/models/resource/processor/GeneralProcessor';
import { ImageProcessor } from '@server/models/resource/processor/ImageProcessor';
import superjson from 'superjson-cjs';
import { Resource } from '@nice/common';
const logger = new Logger('FileProcessorWorker');
const pipeline = new ResourceProcessingPipeline()
.addProcessor(new GeneralProcessor())
.addProcessor(new ImageProcessor())
export default async function processJob(job: Job<any, any, QueueJobType>) {
if (job.name === QueueJobType.FILE_PROCESS) {
console.log(job)
const { resource } = job.data;
if (!resource) {
throw new Error('No resource provided in job data');
}
const result = await pipeline.execute(resource);
return result;
}
}