v1.18.x
Julian Lam 9 years ago
parent 30736c0ee9
commit 10024d7b93

@ -3,6 +3,7 @@
var async = require('async'),
path = require('path'),
fs = require('fs'),
os = require('os'),
nconf = require('nconf'),
crypto = require('crypto'),
winston = require('winston'),
@ -160,20 +161,23 @@ module.exports = function(User) {
md5sum.update(data.imageData);
md5sum = md5sum.digest('hex');
tempPath = path.join(nconf.get('base_dir'), nconf.get('upload_path'), md5sum);
data.file = {
path: path.join(os.tmpdir(), md5sum)
};
var buffer = new Buffer(data.imageData.slice(data.imageData.indexOf('base64') + 7), 'base64');
fs.writeFile(tempPath, buffer, {
fs.writeFile(data.file.path, buffer, {
encoding: 'base64'
}, next);
},
function(next) {
file.isFileTypeAllowed(tempPath, next);
file.isFileTypeAllowed(data.file.path, next);
},
function(tempPath, next) {
var image = {
name: 'profileCover',
path: data.file ? data.file.path : tempPath,
path: tempPath,
uid: data.uid
};
@ -198,7 +202,7 @@ module.exports = function(User) {
User.setUserField(data.uid, 'cover:url', uploadData.url, next);
},
function(next) {
require('fs').unlink(data.file ? data.file.path : tempPath, function(err) {
fs.unlink(data.file.path, function(err) {
if (err) {
winston.error(err);
}
@ -207,7 +211,7 @@ module.exports = function(User) {
}
], function(err) {
if (err) {
return fs.unlink(tempPath, function(unlinkErr) {
return fs.unlink(data.file.path, function(unlinkErr) {
callback(err); // send back the original error
});
}

Loading…
Cancel
Save