Changed PdfFile.filename to exclude file extensions. Other naming fixes
This commit is contained in:
@@ -1,13 +1,13 @@
|
||||
|
||||
import Operations from '../../utils/pdf-operations';
|
||||
import { respondWithPdfFile, response_mustHaveExactlyOneFile } from '../../utils/endpoint-utils';
|
||||
import { respondWithPdfFile, respondWithPdfFiles, response_mustHaveExactlyOneFile } from '../../utils/endpoint-utils';
|
||||
import { PdfFile, PdfFileSchema } from '@stirling-pdf/shared-operations/src/wrappers/PdfFile'
|
||||
|
||||
import express, { Request, Response, RequestHandler } from 'express';
|
||||
const router = express.Router();
|
||||
import multer from 'multer';
|
||||
const upload = multer();
|
||||
import Joi, { array } from 'joi';
|
||||
import Joi from 'joi';
|
||||
|
||||
function registerEndpoint(endpoint: string,
|
||||
nameToAppend: string,
|
||||
@@ -37,32 +37,34 @@ function registerEndpoint(endpoint: string,
|
||||
}
|
||||
|
||||
const processed = await operationFunction(value)
|
||||
if (Array.isArray(processed)) {
|
||||
// TODO zip multiple files
|
||||
} else {
|
||||
processed.filename = appendToFilename(processed.filename, nameToAppend);
|
||||
|
||||
if (body.files && Array.isArray(processed)) { // MIMO
|
||||
respondWithPdfFiles(res, processed, nameToAppend);
|
||||
} else if (body.file && Array.isArray(processed)) { // SIMO
|
||||
respondWithPdfFiles(res, processed, body.file.filename + nameToAppend);
|
||||
} else if (body.files && !Array.isArray(processed)) { // MISO
|
||||
respondWithPdfFile(res, processed);
|
||||
} else if (body.file && !Array.isArray(processed)) { // SISO
|
||||
respondWithPdfFile(res, processed);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* appends a string before the last '.' of the given filename
|
||||
*/
|
||||
function appendToFilename(filename: string, str: string) {
|
||||
return filename.replace(/(\.[^.]+)$/, str+'$1')
|
||||
}
|
||||
|
||||
registerEndpoint("/merge-pdfs", "_merged", upload.single("file"), Operations.mergePDFs, Joi.object({
|
||||
registerEndpoint("/merge-pdfs", "", upload.any(), Operations.mergePDFs, Joi.object({
|
||||
files: Joi.array().items(PdfFileSchema).required(),
|
||||
}).required())
|
||||
}).required());
|
||||
|
||||
registerEndpoint("/rotate-pdf", "_rotated", upload.single("file"), Operations.rotatePages, Joi.object({
|
||||
registerEndpoint("/split-pdf", "_split", upload.single("file"), Operations.splitPDF, Joi.object({
|
||||
file: PdfFileSchema.required(),
|
||||
pageNumbers: Joi.string().required(),
|
||||
}).required());
|
||||
|
||||
registerEndpoint("/rotate-pdf", "", upload.single("file"), Operations.rotatePages, Joi.object({
|
||||
file: PdfFileSchema.required(),
|
||||
rotation: Joi.alternatives().try(Joi.number(), Joi.array().items(Joi.number())).required(),
|
||||
}).required())
|
||||
}).required());
|
||||
|
||||
registerEndpoint("/update-metadata", "_edited-metadata", upload.single("file"), Operations.updateMetadata, Joi.object({
|
||||
registerEndpoint("/update-metadata", "", upload.single("file"), Operations.updateMetadata, Joi.object({
|
||||
file: PdfFileSchema.required(),
|
||||
deleteAll: Joi.string(),
|
||||
author: Joi.string(),
|
||||
@@ -75,6 +77,6 @@ registerEndpoint("/update-metadata", "_edited-metadata", upload.single("file"),
|
||||
title: Joi.string(),
|
||||
trapped: Joi.string(),
|
||||
allRequestParams: Joi.object().pattern(Joi.string(), Joi.string()),
|
||||
}).required())
|
||||
}).required());
|
||||
|
||||
export default router;
|
||||
Reference in New Issue
Block a user