2015-09-25 01:52:41 -04:00
|
|
|
'use strict';
|
|
|
|
|
|
2015-12-25 10:19:15 +02:00
|
|
|
var async = require('async');
|
2015-09-25 13:11:11 -04:00
|
|
|
|
2015-12-25 10:19:15 +02:00
|
|
|
var db = require('../../database');
|
|
|
|
|
var user = require('../../user');
|
2016-02-10 11:33:41 +02:00
|
|
|
var meta = require('../../meta');
|
2016-02-24 18:04:14 -05:00
|
|
|
var plugins = require('../../plugins');
|
2015-12-25 10:19:15 +02:00
|
|
|
var helpers = require('../helpers');
|
2016-04-14 18:41:47 +03:00
|
|
|
var groups = require('../../groups');
|
2015-12-25 10:19:15 +02:00
|
|
|
var accountHelpers = require('./helpers');
|
2016-11-15 12:45:00 +03:00
|
|
|
var privileges = require('../../privileges');
|
2017-05-24 00:02:30 -04:00
|
|
|
var file = require('../../file');
|
2015-09-25 01:52:41 -04:00
|
|
|
|
2017-05-24 00:02:30 -04:00
|
|
|
var editController = module.exports;
|
2015-09-25 01:52:41 -04:00
|
|
|
|
2016-10-13 11:43:39 +02:00
|
|
|
editController.get = function (req, res, callback) {
|
2017-05-24 00:02:30 -04:00
|
|
|
async.waterfall([
|
|
|
|
|
function (next) {
|
|
|
|
|
accountHelpers.getUserDataByUserSlug(req.params.userslug, req.uid, next);
|
|
|
|
|
},
|
|
|
|
|
function (userData, next) {
|
|
|
|
|
if (!userData) {
|
|
|
|
|
return callback();
|
2016-02-24 18:04:14 -05:00
|
|
|
}
|
2017-05-24 00:02:30 -04:00
|
|
|
userData.maximumSignatureLength = parseInt(meta.config.maximumSignatureLength, 10) || 255;
|
|
|
|
|
userData.maximumAboutMeLength = parseInt(meta.config.maximumAboutMeLength, 10) || 1000;
|
|
|
|
|
userData.maximumProfileImageSize = parseInt(meta.config.maximumProfileImageSize, 10);
|
|
|
|
|
userData.allowProfileImageUploads = parseInt(meta.config.allowProfileImageUploads, 10) === 1;
|
|
|
|
|
userData.allowAccountDelete = parseInt(meta.config.allowAccountDelete, 10) === 1;
|
|
|
|
|
userData.profileImageDimension = parseInt(meta.config.profileImageDimension, 10) || 200;
|
|
|
|
|
|
|
|
|
|
userData.groups = userData.groups.filter(function (group) {
|
|
|
|
|
return group && group.userTitleEnabled && !groups.isPrivilegeGroup(group.name) && group.name !== 'registered-users';
|
|
|
|
|
});
|
|
|
|
|
userData.groups.forEach(function (group) {
|
|
|
|
|
group.selected = group.name === userData.groupTitle;
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
userData.title = '[[pages:account/edit, ' + userData.username + ']]';
|
|
|
|
|
userData.breadcrumbs = helpers.buildBreadcrumbs([
|
|
|
|
|
{
|
|
|
|
|
text: userData.username,
|
|
|
|
|
url: '/user/' + userData.userslug,
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
text: '[[user:edit]]',
|
|
|
|
|
},
|
|
|
|
|
]);
|
|
|
|
|
userData.editButtons = [];
|
|
|
|
|
|
|
|
|
|
plugins.fireHook('filter:user.account.edit', userData, next);
|
|
|
|
|
},
|
|
|
|
|
function (userData) {
|
2016-02-24 18:04:14 -05:00
|
|
|
res.render('account/edit', userData);
|
2017-05-24 00:02:30 -04:00
|
|
|
},
|
|
|
|
|
], callback);
|
2015-10-09 17:52:55 -04:00
|
|
|
};
|
|
|
|
|
|
2016-10-13 11:43:39 +02:00
|
|
|
editController.password = function (req, res, next) {
|
2015-10-09 17:52:55 -04:00
|
|
|
renderRoute('password', req, res, next);
|
|
|
|
|
};
|
|
|
|
|
|
2016-10-13 11:43:39 +02:00
|
|
|
editController.username = function (req, res, next) {
|
2015-10-09 17:52:55 -04:00
|
|
|
renderRoute('username', req, res, next);
|
|
|
|
|
};
|
|
|
|
|
|
2016-10-13 11:43:39 +02:00
|
|
|
editController.email = function (req, res, next) {
|
2015-10-09 17:52:55 -04:00
|
|
|
renderRoute('email', req, res, next);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
function renderRoute(name, req, res, next) {
|
2016-10-13 11:43:39 +02:00
|
|
|
getUserData(req, next, function (err, userData) {
|
2016-11-24 11:02:53 +03:00
|
|
|
if (err || !userData) {
|
2015-10-09 17:52:55 -04:00
|
|
|
return next(err);
|
|
|
|
|
}
|
2015-12-25 10:19:15 +02:00
|
|
|
if ((name === 'username' && userData['username:disableEdit']) || (name === 'email' && userData['email:disableEdit'])) {
|
|
|
|
|
return next();
|
|
|
|
|
}
|
2015-10-09 17:52:55 -04:00
|
|
|
|
2016-02-10 12:53:39 +02:00
|
|
|
if (name === 'password') {
|
|
|
|
|
userData.minimumPasswordLength = parseInt(meta.config.minimumPasswordLength, 10);
|
2017-04-07 20:57:00 +00:00
|
|
|
userData.minimumPasswordStrength = parseInt(meta.config.minimumPasswordStrength || 0, 10);
|
2016-02-10 12:53:39 +02:00
|
|
|
}
|
|
|
|
|
|
2015-10-09 17:52:55 -04:00
|
|
|
userData.title = '[[pages:account/edit/' + name + ', ' + userData.username + ']]';
|
2017-04-07 21:39:22 +00:00
|
|
|
userData.breadcrumbs = helpers.buildBreadcrumbs([
|
|
|
|
|
{
|
|
|
|
|
text: userData.username,
|
|
|
|
|
url: '/user/' + userData.userslug,
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
text: '[[user:edit]]',
|
|
|
|
|
url: '/user/' + userData.userslug + '/edit',
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
text: '[[user:' + name + ']]',
|
|
|
|
|
},
|
|
|
|
|
]);
|
2015-10-09 17:52:55 -04:00
|
|
|
|
|
|
|
|
res.render('account/edit/' + name, userData);
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function getUserData(req, next, callback) {
|
2015-09-25 01:52:41 -04:00
|
|
|
var userData;
|
|
|
|
|
async.waterfall([
|
2016-10-13 11:43:39 +02:00
|
|
|
function (next) {
|
2015-09-25 01:52:41 -04:00
|
|
|
accountHelpers.getUserDataByUserSlug(req.params.userslug, req.uid, next);
|
|
|
|
|
},
|
2016-10-13 11:43:39 +02:00
|
|
|
function (data, next) {
|
2015-09-25 01:52:41 -04:00
|
|
|
userData = data;
|
|
|
|
|
if (!userData) {
|
2016-11-24 11:02:53 +03:00
|
|
|
return callback();
|
2015-09-25 01:52:41 -04:00
|
|
|
}
|
|
|
|
|
db.getObjectField('user:' + userData.uid, 'password', next);
|
2017-02-17 19:31:21 -07:00
|
|
|
},
|
2017-05-24 00:02:30 -04:00
|
|
|
function (password, next) {
|
|
|
|
|
userData.hasPassword = !!password;
|
|
|
|
|
next(null, userData);
|
|
|
|
|
},
|
|
|
|
|
], callback);
|
2015-10-09 17:52:55 -04:00
|
|
|
}
|
2015-09-25 13:11:11 -04:00
|
|
|
|
|
|
|
|
editController.uploadPicture = function (req, res, next) {
|
|
|
|
|
var userPhoto = req.files.files[0];
|
|
|
|
|
|
2016-02-16 18:04:02 +02:00
|
|
|
var updateUid;
|
2015-09-25 13:11:11 -04:00
|
|
|
|
|
|
|
|
async.waterfall([
|
2016-10-13 11:43:39 +02:00
|
|
|
function (next) {
|
2015-09-25 13:11:11 -04:00
|
|
|
user.getUidByUserslug(req.params.userslug, next);
|
|
|
|
|
},
|
2016-10-13 11:43:39 +02:00
|
|
|
function (uid, next) {
|
2016-02-16 18:04:02 +02:00
|
|
|
updateUid = uid;
|
2015-09-25 13:11:11 -04:00
|
|
|
|
2016-11-15 12:45:00 +03:00
|
|
|
privileges.users.canEdit(req.uid, uid, next);
|
2015-09-25 13:11:11 -04:00
|
|
|
},
|
2016-10-13 11:43:39 +02:00
|
|
|
function (isAllowed, next) {
|
2016-02-16 18:04:02 +02:00
|
|
|
if (!isAllowed) {
|
|
|
|
|
return helpers.notAllowed(req, res);
|
|
|
|
|
}
|
2016-04-14 18:41:47 +03:00
|
|
|
|
2015-09-25 13:11:11 -04:00
|
|
|
user.uploadPicture(updateUid, userPhoto, next);
|
2017-02-17 19:31:21 -07:00
|
|
|
},
|
2016-10-13 11:43:39 +02:00
|
|
|
], function (err, image) {
|
2017-05-24 00:02:30 -04:00
|
|
|
file.delete(userPhoto.path);
|
2015-09-25 13:11:11 -04:00
|
|
|
if (err) {
|
|
|
|
|
return next(err);
|
|
|
|
|
}
|
|
|
|
|
|
2017-02-19 08:30:30 +00:00
|
|
|
res.json([{
|
|
|
|
|
name: userPhoto.name,
|
2017-02-25 16:04:04 +03:00
|
|
|
url: image.url,
|
2017-02-19 08:30:30 +00:00
|
|
|
}]);
|
2015-09-25 13:11:11 -04:00
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
2016-10-13 11:43:39 +02:00
|
|
|
editController.uploadCoverPicture = function (req, res, next) {
|
2015-10-28 17:42:42 -04:00
|
|
|
var params = JSON.parse(req.body.params);
|
2017-05-24 00:02:30 -04:00
|
|
|
var coverPhoto = req.files.files[0];
|
2015-11-07 18:34:40 -05:00
|
|
|
|
2015-10-28 17:42:42 -04:00
|
|
|
user.updateCoverPicture({
|
2017-05-24 00:02:30 -04:00
|
|
|
file: coverPhoto,
|
2017-02-17 19:31:21 -07:00
|
|
|
uid: params.uid,
|
2016-10-13 11:43:39 +02:00
|
|
|
}, function (err, image) {
|
2017-05-24 00:02:30 -04:00
|
|
|
file.delete(coverPhoto.path);
|
2015-10-28 17:42:42 -04:00
|
|
|
if (err) {
|
|
|
|
|
return next(err);
|
|
|
|
|
}
|
|
|
|
|
|
2017-02-19 08:30:30 +00:00
|
|
|
res.json([{
|
2017-02-23 18:31:49 -07:00
|
|
|
url: image.url,
|
2017-02-19 08:30:30 +00:00
|
|
|
}]);
|
2015-10-28 17:42:42 -04:00
|
|
|
});
|
|
|
|
|
};
|