|
|
|
@ -118,17 +118,16 @@ uploadsController.uploadCategoryPicture = async function (req, res, next) {
|
|
|
|
|
return next(new Error('[[error:invalid-json]]'));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (validateUpload(res, uploadedFile, allowedImageTypes)) {
|
|
|
|
|
await validateUpload(uploadedFile, allowedImageTypes);
|
|
|
|
|
const filename = `category-${params.cid}${path.extname(uploadedFile.name)}`;
|
|
|
|
|
await uploadImage(filename, 'category', uploadedFile, req, res, next);
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
uploadsController.uploadFavicon = async function (req, res, next) {
|
|
|
|
|
const uploadedFile = req.files.files[0];
|
|
|
|
|
const allowedTypes = ['image/x-icon', 'image/vnd.microsoft.icon'];
|
|
|
|
|
|
|
|
|
|
if (validateUpload(res, uploadedFile, allowedTypes)) {
|
|
|
|
|
await validateUpload(uploadedFile, allowedTypes);
|
|
|
|
|
try {
|
|
|
|
|
const imageObj = await file.saveFileToLocal('favicon.ico', 'system', uploadedFile.path);
|
|
|
|
|
res.json([{ name: uploadedFile.name, url: imageObj.url }]);
|
|
|
|
@ -137,7 +136,6 @@ uploadsController.uploadFavicon = async function (req, res, next) {
|
|
|
|
|
} finally {
|
|
|
|
|
file.delete(uploadedFile.path);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
uploadsController.uploadTouchIcon = async function (req, res, next) {
|
|
|
|
@ -145,7 +143,7 @@ uploadsController.uploadTouchIcon = async function (req, res, next) {
|
|
|
|
|
const allowedTypes = ['image/png'];
|
|
|
|
|
const sizes = [36, 48, 72, 96, 144, 192, 512];
|
|
|
|
|
|
|
|
|
|
if (validateUpload(res, uploadedFile, allowedTypes)) {
|
|
|
|
|
await validateUpload(uploadedFile, allowedTypes);
|
|
|
|
|
try {
|
|
|
|
|
const imageObj = await file.saveFileToLocal('touchicon-orig.png', 'system', uploadedFile.path);
|
|
|
|
|
// Resize the image into squares for use as touch icons at various DPIs
|
|
|
|
@ -164,7 +162,6 @@ uploadsController.uploadTouchIcon = async function (req, res, next) {
|
|
|
|
|
} finally {
|
|
|
|
|
file.delete(uploadedFile.path);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -172,7 +169,7 @@ uploadsController.uploadMaskableIcon = async function (req, res, next) {
|
|
|
|
|
const uploadedFile = req.files.files[0];
|
|
|
|
|
const allowedTypes = ['image/png'];
|
|
|
|
|
|
|
|
|
|
if (validateUpload(res, uploadedFile, allowedTypes)) {
|
|
|
|
|
await validateUpload(uploadedFile, allowedTypes);
|
|
|
|
|
try {
|
|
|
|
|
const imageObj = await file.saveFileToLocal('maskableicon-orig.png', 'system', uploadedFile.path);
|
|
|
|
|
res.json([{ name: uploadedFile.name, url: imageObj.url }]);
|
|
|
|
@ -181,7 +178,6 @@ uploadsController.uploadMaskableIcon = async function (req, res, next) {
|
|
|
|
|
} finally {
|
|
|
|
|
file.delete(uploadedFile.path);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
uploadsController.uploadLogo = async function (req, res, next) {
|
|
|
|
@ -219,20 +215,16 @@ uploadsController.uploadOgImage = async function (req, res, next) {
|
|
|
|
|
async function upload(name, req, res, next) {
|
|
|
|
|
const uploadedFile = req.files.files[0];
|
|
|
|
|
|
|
|
|
|
if (validateUpload(res, uploadedFile, allowedImageTypes)) {
|
|
|
|
|
await validateUpload(uploadedFile, allowedImageTypes);
|
|
|
|
|
const filename = name + path.extname(uploadedFile.name);
|
|
|
|
|
await uploadImage(filename, 'system', uploadedFile, req, res, next);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function validateUpload(res, uploadedFile, allowedTypes) {
|
|
|
|
|
async function validateUpload(uploadedFile, allowedTypes) {
|
|
|
|
|
if (!allowedTypes.includes(uploadedFile.type)) {
|
|
|
|
|
file.delete(uploadedFile.path);
|
|
|
|
|
res.json({ error: `[[error:invalid-image-type, ${allowedTypes.join(', ')}]]` });
|
|
|
|
|
return false;
|
|
|
|
|
throw new Error(`[[error:invalid-image-type, ${allowedTypes.join(', ')}]]`);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
async function uploadImage(filename, folder, uploadedFile, req, res, next) {
|
|
|
|
|