| 
									
										
										
										
											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; | 
					
						
							| 
									
										
										
										
											2017-05-27 23:32:55 -04:00
										 |  |  | 			userData.defaultAvatar = user.getDefaultAvatar(); | 
					
						
							| 
									
										
										
										
											2017-05-24 00:02:30 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			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) { | 
					
						
							| 
									
										
										
										
											2017-05-26 16:14:25 -04:00
										 |  |  | 	async.waterfall([ | 
					
						
							|  |  |  | 		function (next) { | 
					
						
							|  |  |  | 			getUserData(req, next, next); | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		function (userData) { | 
					
						
							|  |  |  | 			if (!userData) { | 
					
						
							|  |  |  | 				return next(); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			if ((name === 'username' && userData['username:disableEdit']) || (name === 'email' && userData['email:disableEdit'])) { | 
					
						
							|  |  |  | 				return next(); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			if (name === 'password') { | 
					
						
							|  |  |  | 				userData.minimumPasswordLength = parseInt(meta.config.minimumPasswordLength, 10); | 
					
						
							|  |  |  | 				userData.minimumPasswordStrength = parseInt(meta.config.minimumPasswordStrength || 0, 10); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			userData.title = '[[pages:account/edit/' + name + ', ' + userData.username + ']]'; | 
					
						
							|  |  |  | 			userData.breadcrumbs = helpers.buildBreadcrumbs([ | 
					
						
							|  |  |  | 				{ | 
					
						
							|  |  |  | 					text: userData.username, | 
					
						
							|  |  |  | 					url: '/user/' + userData.userslug, | 
					
						
							|  |  |  | 				}, | 
					
						
							|  |  |  | 				{ | 
					
						
							|  |  |  | 					text: '[[user:edit]]', | 
					
						
							|  |  |  | 					url: '/user/' + userData.userslug + '/edit', | 
					
						
							|  |  |  | 				}, | 
					
						
							|  |  |  | 				{ | 
					
						
							|  |  |  | 					text: '[[user:' + name + ']]', | 
					
						
							|  |  |  | 				}, | 
					
						
							|  |  |  | 			]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			res.render('account/edit/' + name, userData); | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	], next); | 
					
						
							| 
									
										
										
										
											2015-10-09 17:52:55 -04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 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) { | 
					
						
							| 
									
										
										
										
											2017-05-26 16:37:31 -04:00
										 |  |  | 				return callback(null, null); | 
					
						
							| 
									
										
										
										
											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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-15 13:19:25 -05:00
										 |  |  | 			user.uploadCroppedPicture({ | 
					
						
							|  |  |  | 				uid: updateUid, | 
					
						
							|  |  |  | 				file: 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
										 |  |  | 	}); | 
					
						
							|  |  |  | }; |