feat: use updateProfile for picture change

so it triggers action:user:updateProfile
v1.18.x
Barış Soner Uşaklı 4 years ago
parent f806befd2f
commit a598abcd8e

@ -134,6 +134,7 @@ editController.uploadPicture = async function (req, res, next) {
await user.checkMinReputation(req.uid, updateUid, 'min:rep:profile-picture'); await user.checkMinReputation(req.uid, updateUid, 'min:rep:profile-picture');
const image = await user.uploadCroppedPictureFile({ const image = await user.uploadCroppedPictureFile({
callerUid: req.uid,
uid: updateUid, uid: updateUid,
file: userPhoto, file: userPhoto,
}); });

@ -38,10 +38,11 @@ module.exports = function (SocketUser) {
data.bgColor = validBackgrounds[0]; data.bgColor = validBackgrounds[0];
} }
await user.setUserFields(data.uid, { await user.updateProfile(socket.uid, {
picture, uid: data.uid,
picture: picture,
'icon:bgColor': data.bgColor, 'icon:bgColor': data.bgColor,
}); }, ['picture', 'icon:bgColor']);
}; };
SocketUser.removeUploadedPicture = async function (socket, data) { SocketUser.removeUploadedPicture = async function (socket, data) {

@ -108,10 +108,11 @@ module.exports = function (User) {
}); });
await deleteCurrentPicture(data.uid, 'uploadedpicture'); await deleteCurrentPicture(data.uid, 'uploadedpicture');
await User.setUserFields(data.uid, { await User.updateProfile(data.callerUid, {
uid: data.uid,
uploadedpicture: uploadedImage.url, uploadedpicture: uploadedImage.url,
picture: uploadedImage.url, picture: uploadedImage.url,
}); }, ['uploadedpicture', 'picture']);
return uploadedImage; return uploadedImage;
}; };

@ -1,6 +1,7 @@
'use strict'; 'use strict';
const _ = require('lodash');
const async = require('async'); const async = require('async');
const validator = require('validator'); const validator = require('validator');
const winston = require('winston'); const winston = require('winston');
@ -13,11 +14,14 @@ const groups = require('../groups');
const plugins = require('../plugins'); const plugins = require('../plugins');
module.exports = function (User) { module.exports = function (User) {
User.updateProfile = async function (uid, data) { User.updateProfile = async function (uid, data, extraFields) {
let fields = [ let fields = [
'username', 'email', 'fullname', 'website', 'location', 'username', 'email', 'fullname', 'website', 'location',
'groupTitle', 'birthday', 'signature', 'aboutme', 'groupTitle', 'birthday', 'signature', 'aboutme',
]; ];
if (Array.isArray(extraFields)) {
fields = _.uniq(fields.concat(extraFields));
}
if (!data.uid) { if (!data.uid) {
throw new Error('[[error:invalid-update-uid]]'); throw new Error('[[error:invalid-update-uid]]');
} }

@ -871,7 +871,7 @@ describe('User', () => {
signature: 'nodebb is good', signature: 'nodebb is good',
password: '123456', password: '123456',
}; };
socketUser.updateProfile({ uid: uid }, { ...data, password: '123456' }, (err, result) => { socketUser.updateProfile({ uid: uid }, { ...data, password: '123456', invalid: 'field' }, (err, result) => {
assert.ifError(err); assert.ifError(err);
assert.equal(result.username, 'updatedUserName'); assert.equal(result.username, 'updatedUserName');
@ -887,6 +887,8 @@ describe('User', () => {
assert(userData[key].startsWith('$2a$')); assert(userData[key].startsWith('$2a$'));
} }
}); });
// updateProfile only saves valid fields
assert.strictEqual(userData.invalid, undefined);
done(); done();
}); });
}); });

Loading…
Cancel
Save