v1.18.x
Julian Lam 9 years ago
parent 2ce64726ba
commit 3a6ad52ac8

@ -52,7 +52,7 @@ file.base64ToLocal = function(imageData, uploadPath, callback) {
file.isFileTypeAllowed = function(path, callback) { file.isFileTypeAllowed = function(path, callback) {
// Attempt to read the file, if it passes, file type is allowed // Attempt to read the file, if it passes, file type is allowed
jimp.read(path, function(err) { jimp.read(path, function(err) {
callback(err); callback(err, path);
}); });
}; };

@ -9,6 +9,7 @@ var Jimp = require('jimp');
var db = require('../database'); var db = require('../database');
var file = require('../file');
var uploadsController = require('../controllers/uploads'); var uploadsController = require('../controllers/uploads');
module.exports = function(Groups) { module.exports = function(Groups) {
@ -38,7 +39,11 @@ module.exports = function(Groups) {
writeImageDataToFile(data.imageData, next); writeImageDataToFile(data.imageData, next);
}, },
function (_tempPath, next) { function (_tempPath, next) {
tempPath = _tempPath; tempPath = _tempPath; // set in local var so it can be deleted if file type invalid
next(null, tempPath);
},
async.apply(file.isFileTypeAllowed),
function (_tempPath, next) {
uploadsController.uploadGroupCover(uid, { uploadsController.uploadGroupCover(uid, {
name: 'groupCover', name: 'groupCover',
path: tempPath path: tempPath
@ -65,7 +70,9 @@ module.exports = function(Groups) {
} }
], function (err) { ], function (err) {
if (err) { if (err) {
return callback(err); return fs.unlink(tempPath, function(unlinkErr) {
callback(err); // send back original error
});
} }
if (data.position) { if (data.position) {

@ -168,6 +168,9 @@ module.exports = function(User) {
}, next); }, next);
}, },
function(next) { function(next) {
file.isFileTypeAllowed(tempPath, next);
},
function(tempPath, next) {
var image = { var image = {
name: 'profileCover', name: 'profileCover',
path: data.file ? data.file.path : tempPath, path: data.file ? data.file.path : tempPath,
@ -204,7 +207,9 @@ module.exports = function(User) {
} }
], function(err) { ], function(err) {
if (err) { if (err) {
return callback(err); return fs.unlink(tempPath, function(unlinkErr) {
callback(err); // send back the original error
});
} }
if (data.position) { if (data.position) {

Loading…
Cancel
Save