Files
bodyshop-media-server/jobs/jobsUploadMedia.ts
2022-05-18 09:58:08 -07:00

70 lines
2.2 KiB
TypeScript

import { Request, Response } from "express";
import multer from "multer";
import path from "path";
import { logger } from "../server";
import GenerateThumbnail from "../util/generateThumbnail";
import generateUniqueFilename from "../util/generateUniqueFilename";
import { PathToRoFolder } from "../util/pathGenerators";
import { JobsListMedia } from "./jobsListMedia";
import fs from "fs-extra";
export const JobMediaUploadMulter = multer({
storage: multer.diskStorage({
destination: function (req, file, cb) {
const jobid: string = (req.body.jobid || "").trim();
const DestinationFolder: string = PathToRoFolder(jobid);
fs.ensureDirSync(DestinationFolder);
cb(
jobid === "" || jobid === null
? new Error("Job ID not specified.")
: null,
DestinationFolder
);
},
filename: function (req, file, cb) {
logger.debug("Uploading file: ", {
file: path.basename(file.originalname),
});
cb(null, generateUniqueFilename(file));
},
}),
});
export async function jobsUploadMedia(req: Request, res: Response) {
console.time("jobsUploadMedia");
const jobid: string = (req.body.jobid || "").trim();
try {
if (!req.files || (req.files as Express.Multer.File[]).length === 0) {
logger.warning("Upload contained no files.");
res.status(400).send({
status: false,
message: "No file uploaded",
});
} else {
logger.debug(
"Creating thumbnails for newly uploaded media",
(req.files as Express.Multer.File[]).map((f) => f.filename)
);
const thumbnailGenerationQueue: Promise<string>[] = [];
//for each file.path, generate the thumbnail.
(req.files as Express.Multer.File[]).forEach((file) => {
thumbnailGenerationQueue.push(GenerateThumbnail(file.path));
});
await Promise.all(thumbnailGenerationQueue);
console.timeEnd("jobsUploadMedia");
if (req.body.skip_thumbnail) {
res.sendStatus(200);
} else {
JobsListMedia(req, res);
}
}
} catch (error) {
logger.error("Error uploading job media.", { jobid, error: (error as Error).message });
res.status(500).send(error);
}
}