Add extensions for cropped images

v1.18.x
pichalite 8 years ago
parent a379b03e71
commit 8dab8864f6

@ -33,7 +33,9 @@ define('pictureCropper', ['translator', 'cropper'], function (translator, croppe
module.handleImageCrop = function (data, callback) { module.handleImageCrop = function (data, callback) {
$('#crop-picture-modal').remove(); $('#crop-picture-modal').remove();
templates.parse('modals/crop_picture', {url: data.url}, function (cropperHtml) { templates.parse('modals/crop_picture', {
url: data.url
}, function (cropperHtml) {
translator.translate(cropperHtml, function (translated) { translator.translate(cropperHtml, function (translated) {
var cropperModal = $(translated); var cropperModal = $(translated);
cropperModal.modal('show'); cropperModal.modal('show');

@ -6,6 +6,7 @@ var path = require('path');
var winston = require('winston'); var winston = require('winston');
var jimp = require('jimp'); var jimp = require('jimp');
var mkdirp = require('mkdirp'); var mkdirp = require('mkdirp');
var mime = require('mime');
var utils = require('../public/src/utils'); var utils = require('../public/src/utils');
@ -100,7 +101,8 @@ file.existsSync = function (path) {
var exists = false; var exists = false;
try { try {
exists = fs.statSync(path); exists = fs.statSync(path);
} catch(err) { }
catch (err) {
exists = false; exists = false;
} }
@ -110,7 +112,8 @@ file.existsSync = function (path) {
file.link = function link(filePath, destPath, cb) { file.link = function link(filePath, destPath, cb) {
if (process.platform === 'win32') { if (process.platform === 'win32') {
fs.link(filePath, destPath, cb); fs.link(filePath, destPath, cb);
} else { }
else {
fs.symlink(filePath, destPath, 'file', cb); fs.symlink(filePath, destPath, 'file', cb);
} }
}; };
@ -120,4 +123,12 @@ file.linkDirs = function linkDirs(sourceDir, destDir, callback) {
fs.symlink(sourceDir, destDir, type, callback); fs.symlink(sourceDir, destDir, type, callback);
}; };
file.typeToExtension = function (type) {
var extension;
if (type) {
extension = '.' + mime.extension(type);
}
return extension;
};
module.exports = file; module.exports = file;

@ -8,7 +8,6 @@ var nconf = require('nconf');
var crypto = require('crypto'); var crypto = require('crypto');
var winston = require('winston'); var winston = require('winston');
var request = require('request'); var request = require('request');
var mime = require('mime');
var plugins = require('../plugins'); var plugins = require('../plugins');
var file = require('../file'); var file = require('../file');
@ -43,7 +42,10 @@ module.exports = function (User) {
async.waterfall([ async.waterfall([
function (next) { function (next) {
if (plugins.hasListeners('filter:uploadImage')) { if (plugins.hasListeners('filter:uploadImage')) {
return plugins.fireHook('filter:uploadImage', {image: picture, uid: updateUid}, next); return plugins.fireHook('filter:uploadImage', {
image: picture,
uid: updateUid
}, next);
} }
var filename = updateUid + '-profileimg' + (keepAllVersions ? '-' + Date.now() : '') + (convertToPNG ? '.png' : extension); var filename = updateUid + '-profileimg' + (keepAllVersions ? '-' + Date.now() : '') + (convertToPNG ? '.png' : extension);
@ -79,7 +81,10 @@ module.exports = function (User) {
}, },
function (_image, next) { function (_image, next) {
uploadedImage = _image; uploadedImage = _image;
User.setUserFields(updateUid, {uploadedpicture: uploadedImage.url, picture: uploadedImage.url}, next); User.setUserFields(updateUid, {
uploadedpicture: uploadedImage.url,
picture: uploadedImage.url
}, next);
}, },
function (next) { function (next) {
next(null, uploadedImage); next(null, uploadedImage);
@ -99,7 +104,7 @@ module.exports = function (User) {
var uploadSize = parseInt(meta.config.maximumProfileImageSize, 10) || 256; var uploadSize = parseInt(meta.config.maximumProfileImageSize, 10) || 256;
var size = res.headers['content-length']; var size = res.headers['content-length'];
var type = res.headers['content-type']; var type = res.headers['content-type'];
var extension = mime.extension(type); var extension = file.typeToExtension(type);
if (['png', 'jpeg', 'jpg', 'gif'].indexOf(extension) === -1) { if (['png', 'jpeg', 'jpg', 'gif'].indexOf(extension) === -1) {
return callback(new Error('[[error:invalid-image-extension]]')); return callback(new Error('[[error:invalid-image-extension]]'));
@ -109,12 +114,21 @@ module.exports = function (User) {
return callback(new Error('[[error:file-too-big, ' + uploadSize + ']]')); return callback(new Error('[[error:file-too-big, ' + uploadSize + ']]'));
} }
var picture = {url: url, name: ''}; var picture = {
plugins.fireHook('filter:uploadImage', {image: picture, uid: uid}, function (err, image) { url: url,
name: ''
};
plugins.fireHook('filter:uploadImage', {
image: picture,
uid: uid
}, function (err, image) {
if (err) { if (err) {
return callback(err); return callback(err);
} }
User.setUserFields(uid, {uploadedpicture: image.url, picture: image.url}); User.setUserFields(uid, {
uploadedpicture: image.url,
picture: image.url
});
callback(null, image); callback(null, image);
}); });
}); });
@ -170,10 +184,14 @@ module.exports = function (User) {
}; };
if (plugins.hasListeners('filter:uploadImage')) { if (plugins.hasListeners('filter:uploadImage')) {
return plugins.fireHook('filter:uploadImage', {image: image, uid: data.uid}, next); return plugins.fireHook('filter:uploadImage', {
image: image,
uid: data.uid
}, next);
} }
var filename = data.uid + '-profilecover' + (keepAllVersions ? '-' + Date.now() : ''); var extension = file.typeToExtension(data.imageData.slice(5, data.imageData.indexOf('base64') - 1));
var filename = data.uid + '-profilecover' + (keepAllVersions ? '-' + Date.now() : '') + (extension || '');
async.waterfall([ async.waterfall([
function (next) { function (next) {
file.isFileTypeAllowed(data.file.path, next); file.isFileTypeAllowed(data.file.path, next);
@ -214,10 +232,15 @@ module.exports = function (User) {
if (data.position) { if (data.position) {
User.updateCoverPosition(data.uid, data.position, function (err) { User.updateCoverPosition(data.uid, data.position, function (err) {
callback(err, {url: url}); callback(err, {
url: url
});
});
}
else {
callback(err, {
url: url
}); });
} else {
callback(err, {url: url});
} }
}); });
}; };
@ -260,10 +283,14 @@ module.exports = function (User) {
}; };
if (plugins.hasListeners('filter:uploadImage')) { if (plugins.hasListeners('filter:uploadImage')) {
return plugins.fireHook('filter:uploadImage', {image: image, uid: data.uid}, next); return plugins.fireHook('filter:uploadImage', {
image: image,
uid: data.uid
}, next);
} }
var filename = data.uid + '-profileavatar' + (keepAllVersions ? '-' + Date.now() : ''); var extension = file.typeToExtension(data.imageData.slice(5, data.imageData.indexOf('base64') - 1));
var filename = data.uid + '-profileavatar' + (keepAllVersions ? '-' + Date.now() : '') + (extension || '');
async.waterfall([ async.waterfall([
function (next) { function (next) {
file.isFileTypeAllowed(data.file.path, next); file.isFileTypeAllowed(data.file.path, next);
@ -281,7 +308,10 @@ module.exports = function (User) {
}, },
function (uploadData, next) { function (uploadData, next) {
url = uploadData.url; url = uploadData.url;
User.setUserFields(data.uid, {uploadedpicture: url, picture: url}, next); User.setUserFields(data.uid, {
uploadedpicture: url,
picture: url
}, next);
}, },
function (next) { function (next) {
fs.unlink(data.file.path, function (err) { fs.unlink(data.file.path, function (err) {
@ -296,7 +326,9 @@ module.exports = function (User) {
callback(err); // send back the original error callback(err); // send back the original error
} }
callback(err, {url: url}); callback(err, {
url: url
});
}); });
}; };

Loading…
Cancel
Save