| 
									
										
										
										
											2015-09-25 01:52:41 -04:00
										 |  |  | 'use strict'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-25 10:19:15 +02:00
										 |  |  | var async = require('async'); | 
					
						
							|  |  |  | var fs = require('fs'); | 
					
						
							|  |  |  | var nconf = require('nconf'); | 
					
						
							|  |  |  | var winston = require('winston'); | 
					
						
							| 
									
										
										
										
											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'); | 
					
						
							|  |  |  | var accountHelpers = require('./helpers'); | 
					
						
							| 
									
										
										
										
											2015-09-25 01:52:41 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | var editController = {}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | editController.get = function(req, res, callback) { | 
					
						
							| 
									
										
										
										
											2015-10-09 17:52:55 -04:00
										 |  |  | 	accountHelpers.getUserDataByUserSlug(req.params.userslug, req.uid, function(err, userData) { | 
					
						
							|  |  |  | 		if (err || !userData) { | 
					
						
							|  |  |  | 			return callback(err); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-10 11:33:41 +02:00
										 |  |  | 		userData.maximumSignatureLength = parseInt(meta.config.maximumSignatureLength, 10) || 255; | 
					
						
							|  |  |  | 		userData.maximumAboutMeLength = parseInt(meta.config.maximumAboutMeLength, 10) || 1000; | 
					
						
							| 
									
										
										
										
											2016-02-10 12:53:39 +02:00
										 |  |  | 		userData.maximumProfileImageSize = parseInt(meta.config.maximumProfileImageSize, 10); | 
					
						
							|  |  |  | 		userData.allowProfileImageUploads = parseInt(meta.config.allowProfileImageUploads) === 1; | 
					
						
							|  |  |  | 		userData.allowAccountDelete = parseInt(meta.config.allowAccountDelete, 10) === 1; | 
					
						
							| 
									
										
										
										
											2016-02-16 18:04:02 +02:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2016-02-10 11:33:41 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-09 17:52:55 -04:00
										 |  |  | 		userData.title = '[[pages:account/edit, ' + userData.username + ']]'; | 
					
						
							|  |  |  | 		userData.breadcrumbs = helpers.buildBreadcrumbs([{text: userData.username, url: '/user/' + userData.userslug}, {text: '[[user:edit]]'}]); | 
					
						
							| 
									
										
										
										
											2016-02-24 18:04:14 -05:00
										 |  |  | 		userData.editButtons = []; | 
					
						
							| 
									
										
										
										
											2015-10-09 17:52:55 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-24 18:04:14 -05:00
										 |  |  | 		plugins.fireHook('filter:user.account.edit', userData, function(err, userData) { | 
					
						
							|  |  |  | 			if (err) { | 
					
						
							|  |  |  | 				return next(err); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			res.render('account/edit', userData); | 
					
						
							|  |  |  | 		}); | 
					
						
							| 
									
										
										
										
											2015-10-09 17:52:55 -04:00
										 |  |  | 	}); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | editController.password = function(req, res, next) { | 
					
						
							|  |  |  | 	renderRoute('password', req, res, next); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | editController.username = function(req, res, next) { | 
					
						
							|  |  |  | 	renderRoute('username', req, res, next); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | editController.email = function(req, res, next) { | 
					
						
							|  |  |  | 	renderRoute('email', req, res, next); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function renderRoute(name, req, res, next) { | 
					
						
							|  |  |  | 	getUserData(req, next, function(err, userData) { | 
					
						
							|  |  |  | 		if (err) { | 
					
						
							|  |  |  | 			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); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-09 17:52:55 -04:00
										 |  |  | 		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); | 
					
						
							|  |  |  | 	}); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function getUserData(req, next, callback) { | 
					
						
							| 
									
										
										
										
											2015-09-25 01:52:41 -04:00
										 |  |  | 	var userData; | 
					
						
							|  |  |  | 	async.waterfall([ | 
					
						
							|  |  |  | 		function(next) { | 
					
						
							|  |  |  | 			accountHelpers.getUserDataByUserSlug(req.params.userslug, req.uid, next); | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		function(data, next) { | 
					
						
							|  |  |  | 			userData = data; | 
					
						
							|  |  |  | 			if (!userData) { | 
					
						
							| 
									
										
										
										
											2015-10-09 17:52:55 -04:00
										 |  |  | 				return next(); | 
					
						
							| 
									
										
										
										
											2015-09-25 01:52:41 -04:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			db.getObjectField('user:' + userData.uid, 'password', next); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	], function(err, password) { | 
					
						
							|  |  |  | 		if (err) { | 
					
						
							|  |  |  | 			return callback(err); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		userData.hasPassword = !!password; | 
					
						
							| 
									
										
										
										
											2015-10-09 17:52:55 -04:00
										 |  |  | 		callback(null, userData); | 
					
						
							| 
									
										
										
										
											2015-09-25 01:52:41 -04:00
										 |  |  | 	}); | 
					
						
							| 
									
										
										
										
											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([ | 
					
						
							|  |  |  | 		function(next) { | 
					
						
							|  |  |  | 			user.getUidByUserslug(req.params.userslug, next); | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		function(uid, next) { | 
					
						
							| 
									
										
										
										
											2016-02-16 18:04:02 +02:00
										 |  |  | 			updateUid = uid; | 
					
						
							|  |  |  | 			if (parseInt(req.uid, 10) === parseInt(uid, 10)) { | 
					
						
							|  |  |  | 				return next(null, true); | 
					
						
							| 
									
										
										
										
											2015-09-25 13:11:11 -04:00
										 |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-16 18:04:02 +02:00
										 |  |  | 			user.isAdminOrGlobalMod(req.uid, next); | 
					
						
							| 
									
										
										
										
											2015-09-25 13:11:11 -04:00
										 |  |  | 		}, | 
					
						
							| 
									
										
										
										
											2016-02-16 18:04:02 +02:00
										 |  |  | 		function(isAllowed, next) { | 
					
						
							|  |  |  | 			if (!isAllowed) { | 
					
						
							|  |  |  | 				return helpers.notAllowed(req, res); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			 | 
					
						
							| 
									
										
										
										
											2015-09-25 13:11:11 -04:00
										 |  |  | 			user.uploadPicture(updateUid, userPhoto, next); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	], function(err, image) { | 
					
						
							|  |  |  | 		fs.unlink(userPhoto.path, function(err) { | 
					
						
							| 
									
										
										
										
											2016-04-07 17:47:17 -04:00
										 |  |  | 			if (err) { | 
					
						
							|  |  |  | 				winston.warn('[user/picture] Unable to delete picture ' + userPhoto.path, err); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2015-09-25 13:11:11 -04:00
										 |  |  | 		}); | 
					
						
							|  |  |  | 		if (err) { | 
					
						
							|  |  |  | 			return next(err); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		res.json([{name: userPhoto.name, url: image.url.startsWith('http') ? image.url : nconf.get('relative_path') + image.url}]); | 
					
						
							|  |  |  | 	}); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-28 17:42:42 -04:00
										 |  |  | editController.uploadCoverPicture = function(req, res, next) { | 
					
						
							|  |  |  | 	var params = JSON.parse(req.body.params); | 
					
						
							| 
									
										
										
										
											2015-11-07 18:34:40 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-28 17:42:42 -04:00
										 |  |  | 	user.updateCoverPicture({ | 
					
						
							| 
									
										
										
										
											2015-11-07 18:34:40 -05:00
										 |  |  | 		file: req.files.files[0], | 
					
						
							| 
									
										
										
										
											2015-10-28 17:42:42 -04:00
										 |  |  | 		uid: params.uid | 
					
						
							|  |  |  | 	}, function(err, image) { | 
					
						
							|  |  |  | 		if (err) { | 
					
						
							|  |  |  | 			return next(err); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-11-05 15:49:10 -05:00
										 |  |  | 		res.json([{ url: image.url }]); | 
					
						
							| 
									
										
										
										
											2015-10-28 17:42:42 -04:00
										 |  |  | 	}); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-25 01:52:41 -04:00
										 |  |  | module.exports = editController; |