mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-11-01 19:46:01 +01:00
closes #3005
This commit is contained in:
@@ -203,7 +203,7 @@ define('forum/account/edit', ['forum/account/header', 'uploader', 'translator'],
|
|||||||
if (!url) {
|
if (!url) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
socket.emit('user.uploadProfileImageFromUrl', url, function(err, imageUrlOnServer) {
|
socket.emit('user.uploadProfileImageFromUrl', {url: url, uid: ajaxify.variables.get('theirid')}, function(err, imageUrlOnServer) {
|
||||||
if (err) {
|
if (err) {
|
||||||
return app.alertError(err.message);
|
return app.alertError(err.message);
|
||||||
}
|
}
|
||||||
@@ -300,7 +300,7 @@ define('forum/account/edit', ['forum/account/header', 'uploader', 'translator'],
|
|||||||
} else {
|
} else {
|
||||||
if (!passwordsmatch) {
|
if (!passwordsmatch) {
|
||||||
app.alertError('[[user:change_password_error_match]]');
|
app.alertError('[[user:change_password_error_match]]');
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!passwordvalid) {
|
if (!passwordvalid) {
|
||||||
app.alertError('[[user:change_password_error]]');
|
app.alertError('[[user:change_password_error]]');
|
||||||
|
|||||||
@@ -3,8 +3,6 @@
|
|||||||
var accountsController = {};
|
var accountsController = {};
|
||||||
|
|
||||||
var fs = require('fs'),
|
var fs = require('fs'),
|
||||||
path = require('path'),
|
|
||||||
winston = require('winston'),
|
|
||||||
nconf = require('nconf'),
|
nconf = require('nconf'),
|
||||||
async = require('async'),
|
async = require('async'),
|
||||||
validator = require('validator'),
|
validator = require('validator'),
|
||||||
@@ -20,8 +18,7 @@ var fs = require('fs'),
|
|||||||
meta = require('../meta'),
|
meta = require('../meta'),
|
||||||
plugins = require('../plugins'),
|
plugins = require('../plugins'),
|
||||||
languages = require('../languages'),
|
languages = require('../languages'),
|
||||||
image = require('../image'),
|
|
||||||
file = require('../file'),
|
|
||||||
helpers = require('./helpers');
|
helpers = require('./helpers');
|
||||||
|
|
||||||
function getUserDataByUserSlug(userslug, callerUID, callback) {
|
function getUserDataByUserSlug(userslug, callerUID, callback) {
|
||||||
@@ -369,32 +366,10 @@ accountsController.accountSettings = function(req, res, next) {
|
|||||||
|
|
||||||
accountsController.uploadPicture = function (req, res, next) {
|
accountsController.uploadPicture = function (req, res, next) {
|
||||||
var userPhoto = req.files.files[0];
|
var userPhoto = req.files.files[0];
|
||||||
var uploadSize = parseInt(meta.config.maximumProfileImageSize, 10) || 256;
|
|
||||||
var extension = path.extname(userPhoto.name);
|
|
||||||
var updateUid = req.uid;
|
var updateUid = req.uid;
|
||||||
var imageDimension = parseInt(meta.config.profileImageDimension, 10) || 128;
|
|
||||||
var convertToPNG = parseInt(meta.config['profile:convertProfileImageToPNG'], 10) === 1;
|
|
||||||
|
|
||||||
async.waterfall([
|
async.waterfall([
|
||||||
function(next) {
|
|
||||||
next(userPhoto.size > uploadSize * 1024 ? new Error('[[error:file-too-big, ' + uploadSize + ']]') : null);
|
|
||||||
},
|
|
||||||
function(next) {
|
|
||||||
next(!extension ? new Error('[[error:invalid-image-extension]]') : null);
|
|
||||||
},
|
|
||||||
function(next) {
|
|
||||||
file.isFileTypeAllowed(userPhoto.path, ['png', 'jpeg', 'jpg', 'gif'], next);
|
|
||||||
},
|
|
||||||
function(next) {
|
|
||||||
image.resizeImage(userPhoto.path, extension, imageDimension, imageDimension, next);
|
|
||||||
},
|
|
||||||
function(next) {
|
|
||||||
if (convertToPNG) {
|
|
||||||
image.convertImageToPng(userPhoto.path, extension, next);
|
|
||||||
} else {
|
|
||||||
next();
|
|
||||||
}
|
|
||||||
},
|
|
||||||
function(next) {
|
function(next) {
|
||||||
user.getUidByUserslug(req.params.userslug, next);
|
user.getUidByUserslug(req.params.userslug, next);
|
||||||
},
|
},
|
||||||
@@ -414,50 +389,17 @@ accountsController.uploadPicture = function (req, res, next) {
|
|||||||
updateUid = uid;
|
updateUid = uid;
|
||||||
next();
|
next();
|
||||||
});
|
});
|
||||||
|
},
|
||||||
|
function(next) {
|
||||||
|
user.uploadPicture(updateUid, userPhoto, next);
|
||||||
}
|
}
|
||||||
], function(err, result) {
|
], function(err, image) {
|
||||||
|
fs.unlink(userPhoto.path);
|
||||||
function done(err, image) {
|
|
||||||
fs.unlink(userPhoto.path);
|
|
||||||
if (err) {
|
|
||||||
return res.json({error: err.message});
|
|
||||||
}
|
|
||||||
|
|
||||||
user.setUserFields(updateUid, {uploadedpicture: image.url, picture: image.url});
|
|
||||||
|
|
||||||
res.json([{name: userPhoto.name, url: image.url.startsWith('http') ? image.url : nconf.get('relative_path') + image.url}]);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (err) {
|
if (err) {
|
||||||
fs.unlink(userPhoto.path);
|
|
||||||
return next(err);
|
return next(err);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (plugins.hasListeners('filter:uploadImage')) {
|
res.json([{name: userPhoto.name, url: image.url.startsWith('http') ? image.url : nconf.get('relative_path') + image.url}]);
|
||||||
return plugins.fireHook('filter:uploadImage', {image: userPhoto, uid: updateUid}, done);
|
|
||||||
}
|
|
||||||
|
|
||||||
var filename = updateUid + '-profileimg' + (convertToPNG ? '.png' : extension);
|
|
||||||
|
|
||||||
user.getUserField(updateUid, 'uploadedpicture', function (err, oldpicture) {
|
|
||||||
if (err) {
|
|
||||||
return next(err);
|
|
||||||
}
|
|
||||||
if (!oldpicture) {
|
|
||||||
file.saveFileToLocal(filename, 'profile', userPhoto.path, done);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var absolutePath = path.join(nconf.get('base_dir'), nconf.get('upload_path'), 'profile', path.basename(oldpicture));
|
|
||||||
|
|
||||||
fs.unlink(absolutePath, function (err) {
|
|
||||||
if (err) {
|
|
||||||
winston.error(err);
|
|
||||||
}
|
|
||||||
|
|
||||||
file.saveFileToLocal(filename, 'profile', userPhoto.path, done);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
@@ -263,19 +263,27 @@ SocketUser.changePicture = function(socket, data, callback) {
|
|||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
SocketUser.uploadProfileImageFromUrl = function(socket, url, callback) {
|
SocketUser.uploadProfileImageFromUrl = function(socket, data, callback) {
|
||||||
if (!socket.uid || !url) {
|
function upload() {
|
||||||
|
user.uploadFromUrl(data.uid, data.url, function(err, uploadedImage) {
|
||||||
|
callback(err, uploadedImage ? uploadedImage.url : null);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!socket.uid || !data.url || !data.uid) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
plugins.fireHook('filter:uploadImage', {image: {url: url}, uid: socket.uid}, function(err, data) {
|
if (parseInt(socket.uid, 10) === parseInt(data.uid, 10)) {
|
||||||
if (err) {
|
return upload();
|
||||||
return callback(err);
|
}
|
||||||
|
|
||||||
|
user.isAdministrator(socket.uid, function(err, isAdmin) {
|
||||||
|
if (err || !isAdmin) {
|
||||||
|
return callback(err || new Error('[[error:not-allowed]]'));
|
||||||
}
|
}
|
||||||
|
|
||||||
user.setUserFields(socket.uid, {uploadedpicture: data.url, picture: data.url}, function(err) {
|
upload();
|
||||||
callback(err, data.url);
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
@@ -29,6 +29,7 @@ var async = require('async'),
|
|||||||
require('./user/settings')(User);
|
require('./user/settings')(User);
|
||||||
require('./user/search')(User);
|
require('./user/search')(User);
|
||||||
require('./user/jobs')(User);
|
require('./user/jobs')(User);
|
||||||
|
require('./user/picture')(User);
|
||||||
|
|
||||||
User.getUserField = function(uid, field, callback) {
|
User.getUserField = function(uid, field, callback) {
|
||||||
User.getUserFields(uid, [field], function(err, user) {
|
User.getUserFields(uid, [field], function(err, user) {
|
||||||
|
|||||||
131
src/user/picture.js
Normal file
131
src/user/picture.js
Normal file
@@ -0,0 +1,131 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
var async = require('async'),
|
||||||
|
path = require('path'),
|
||||||
|
fs = require('fs'),
|
||||||
|
nconf = require('nconf'),
|
||||||
|
winston = require('winston'),
|
||||||
|
request = require('request'),
|
||||||
|
mime = require('mime'),
|
||||||
|
|
||||||
|
plugins = require('../plugins'),
|
||||||
|
file = require('../file'),
|
||||||
|
image = require('../image'),
|
||||||
|
meta = require('../meta');
|
||||||
|
|
||||||
|
module.exports = function(User) {
|
||||||
|
|
||||||
|
User.uploadPicture = function (uid, picture, callback) {
|
||||||
|
|
||||||
|
var uploadSize = parseInt(meta.config.maximumProfileImageSize, 10) || 256;
|
||||||
|
var extension = path.extname(picture.name);
|
||||||
|
var updateUid = uid;
|
||||||
|
var imageDimension = parseInt(meta.config.profileImageDimension, 10) || 128;
|
||||||
|
var convertToPNG = parseInt(meta.config['profile:convertProfileImageToPNG'], 10) === 1;
|
||||||
|
|
||||||
|
async.waterfall([
|
||||||
|
function(next) {
|
||||||
|
next(picture.size > uploadSize * 1024 ? new Error('[[error:file-too-big, ' + uploadSize + ']]') : null);
|
||||||
|
},
|
||||||
|
function(next) {
|
||||||
|
next(!extension ? new Error('[[error:invalid-image-extension]]') : null);
|
||||||
|
},
|
||||||
|
function(next) {
|
||||||
|
file.isFileTypeAllowed(picture.path, ['png', 'jpeg', 'jpg', 'gif'], next);
|
||||||
|
},
|
||||||
|
function(next) {
|
||||||
|
image.resizeImage(picture.path, extension, imageDimension, imageDimension, next);
|
||||||
|
},
|
||||||
|
function(next) {
|
||||||
|
if (convertToPNG) {
|
||||||
|
image.convertImageToPng(picture.path, extension, next);
|
||||||
|
} else {
|
||||||
|
next();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
], function(err, result) {
|
||||||
|
|
||||||
|
function done(err, image) {
|
||||||
|
if (err) {
|
||||||
|
return callback(err);
|
||||||
|
}
|
||||||
|
|
||||||
|
User.setUserFields(updateUid, {uploadedpicture: image.url, picture: image.url});
|
||||||
|
|
||||||
|
callback(null, image);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (err) {
|
||||||
|
return callback(err);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (plugins.hasListeners('filter:uploadImage')) {
|
||||||
|
return plugins.fireHook('filter:uploadImage', {image: picture, uid: updateUid}, done);
|
||||||
|
}
|
||||||
|
|
||||||
|
var filename = updateUid + '-profileimg' + (convertToPNG ? '.png' : extension);
|
||||||
|
|
||||||
|
User.getUserField(updateUid, 'uploadedpicture', function (err, oldpicture) {
|
||||||
|
if (err) {
|
||||||
|
return callback(err);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!oldpicture) {
|
||||||
|
return file.saveFileToLocal(filename, 'profile', picture.path, done);
|
||||||
|
}
|
||||||
|
|
||||||
|
var absolutePath = path.join(nconf.get('base_dir'), nconf.get('upload_path'), 'profile', path.basename(oldpicture));
|
||||||
|
|
||||||
|
fs.unlink(absolutePath, function (err) {
|
||||||
|
if (err) {
|
||||||
|
winston.error(err);
|
||||||
|
}
|
||||||
|
|
||||||
|
file.saveFileToLocal(filename, 'profile', picture.path, done);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
User.uploadFromUrl = function(uid, url, callback) {
|
||||||
|
var filename = 'uid:' + uid + ':tmp-image';
|
||||||
|
downloadFromUrl(url, filename, function(err, downloadedImage) {
|
||||||
|
if (err) {
|
||||||
|
return callback(err);
|
||||||
|
}
|
||||||
|
|
||||||
|
User.uploadPicture(uid, downloadedImage, function(err, image) {
|
||||||
|
fs.unlink(filename);
|
||||||
|
callback(err, image);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
function downloadFromUrl(url, filename, callback) {
|
||||||
|
request.head(url, function(err, res, body) {
|
||||||
|
if (err) {
|
||||||
|
return callback(err);
|
||||||
|
}
|
||||||
|
var uploadSize = parseInt(meta.config.maximumProfileImageSize, 10) || 256;
|
||||||
|
var size = res.headers['content-length'];
|
||||||
|
var type = res.headers['content-type'];
|
||||||
|
var extension = mime.extension(type);
|
||||||
|
|
||||||
|
if (size > uploadSize * 1024) {
|
||||||
|
return callback(new Error('[[error:file-too-big, ' + uploadSize + ']]'));
|
||||||
|
}
|
||||||
|
|
||||||
|
request.get(url)
|
||||||
|
.on('error', function(err) {
|
||||||
|
winston.error(err);
|
||||||
|
})
|
||||||
|
.pipe(fs.createWriteStream(filename))
|
||||||
|
.on('close', function(err) {
|
||||||
|
if (err) {
|
||||||
|
return callback(err);
|
||||||
|
}
|
||||||
|
callback(null, {path: filename, size: size, type: type, name: filename + '.' + extension});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
};
|
||||||
Reference in New Issue
Block a user