2014-04-09 13:50:12 +00:00
|
|
|
UserDeleter = require("./UserDeleter")
|
2014-04-09 15:59:28 +00:00
|
|
|
UserLocator = require("./UserLocator")
|
2014-04-09 15:33:54 +00:00
|
|
|
User = require("../../models/User").User
|
2014-04-09 14:41:19 +00:00
|
|
|
newsLetterManager = require('../Newsletter/NewsletterManager')
|
2014-04-10 13:43:06 +00:00
|
|
|
UserRegistrationHandler = require("./UserRegistrationHandler")
|
2014-04-09 15:33:54 +00:00
|
|
|
logger = require("logger-sharelatex")
|
2014-04-09 15:59:28 +00:00
|
|
|
metrics = require("../../infrastructure/Metrics")
|
2014-04-10 13:43:06 +00:00
|
|
|
Url = require("url")
|
|
|
|
AuthenticationController = require("../Authentication/AuthenticationController")
|
2014-04-10 16:15:18 +00:00
|
|
|
AuthenticationManager = require("../Authentication/AuthenticationManager")
|
2014-04-15 12:59:00 +00:00
|
|
|
ReferalAllocator = require("../Referal/ReferalAllocator")
|
2014-05-16 16:45:48 +00:00
|
|
|
UserUpdater = require("./UserUpdater")
|
2014-04-10 16:15:18 +00:00
|
|
|
|
2014-04-09 13:50:12 +00:00
|
|
|
module.exports =
|
|
|
|
|
|
|
|
deleteUser: (req, res)->
|
|
|
|
user_id = req.session.user._id
|
|
|
|
UserDeleter.deleteUser user_id, (err)->
|
|
|
|
if !err?
|
|
|
|
req.session.destroy()
|
2014-04-09 14:41:19 +00:00
|
|
|
res.send(200)
|
|
|
|
|
|
|
|
unsubscribe: (req, res)->
|
|
|
|
UserLocator.findById req.session.user._id, (err, user)->
|
|
|
|
newsLetterManager.unsubscribe user, ->
|
2014-04-09 15:33:54 +00:00
|
|
|
res.send()
|
|
|
|
|
|
|
|
updateUserSettings : (req, res)->
|
|
|
|
logger.log user: req.session.user, "updating account settings"
|
2014-05-19 10:50:32 +00:00
|
|
|
user_id = req.session.user._id
|
|
|
|
User.findById user_id, (err, user)->
|
2014-04-09 15:33:54 +00:00
|
|
|
if err? or !user?
|
2014-05-19 10:50:32 +00:00
|
|
|
logger.err err:err, user_id:user_id, "problem updaing user settings"
|
2014-04-09 15:33:54 +00:00
|
|
|
return res.send 500
|
2014-06-20 08:42:43 +00:00
|
|
|
|
|
|
|
if req.body.first_name?
|
|
|
|
user.first_name = req.body.first_name.trim()
|
|
|
|
if req.body.last_name?
|
|
|
|
user.last_name = req.body.last_name.trim()
|
2014-06-20 10:15:25 +00:00
|
|
|
if req.body.role?
|
|
|
|
user.role = req.body.role.trim()
|
|
|
|
if req.body.institution?
|
|
|
|
user.institution = req.body.institution.trim()
|
2014-06-20 08:42:43 +00:00
|
|
|
if req.body.mode?
|
|
|
|
user.ace.mode = req.body.mode
|
|
|
|
if req.body.theme?
|
|
|
|
user.ace.theme = req.body.theme
|
|
|
|
if req.body.fontSize?
|
|
|
|
user.ace.fontSize = req.body.fontSize
|
|
|
|
if req.body.autoComplete?
|
2014-06-24 20:09:20 +00:00
|
|
|
user.ace.autoComplete = req.body.autoComplete
|
2014-06-20 08:42:43 +00:00
|
|
|
if req.body.spellCheckLanguage?
|
|
|
|
user.ace.spellCheckLanguage = req.body.spellCheckLanguage
|
|
|
|
if req.body.pdfViewer?
|
|
|
|
user.ace.pdfViewer = req.body.pdfViewer
|
2014-05-19 10:50:32 +00:00
|
|
|
user.save (err)->
|
2014-10-13 14:44:45 +00:00
|
|
|
newEmail = req.body.email?.trim().toLowerCase()
|
2014-06-20 08:42:43 +00:00
|
|
|
if !newEmail? or newEmail == user.email
|
2014-05-19 10:50:32 +00:00
|
|
|
return res.send 200
|
2014-06-20 08:42:43 +00:00
|
|
|
else if newEmail.indexOf("@") == -1
|
|
|
|
return res.send(400)
|
2014-05-20 12:18:59 +00:00
|
|
|
else
|
2014-05-19 10:50:32 +00:00
|
|
|
UserUpdater.changeEmailAddress user_id, newEmail, (err)->
|
|
|
|
if err?
|
|
|
|
logger.err err:err, user_id:user_id, newEmail:newEmail, "problem updaing users email address"
|
2014-08-01 13:03:38 +00:00
|
|
|
if err.message == "alread_exists"
|
|
|
|
message = req.i18n.translate("alread_exists")
|
|
|
|
else
|
|
|
|
message = req.i18n.translate("problem_changing_email_address")
|
|
|
|
return res.send 500, {message:message}
|
2014-05-19 10:50:32 +00:00
|
|
|
res.send(200)
|
2014-04-09 15:59:28 +00:00
|
|
|
|
|
|
|
logout : (req, res)->
|
|
|
|
metrics.inc "user.logout"
|
|
|
|
logger.log user: req?.session?.user, "logging out"
|
|
|
|
req.session.destroy (err)->
|
|
|
|
if err
|
|
|
|
logger.err err: err, 'error destorying session'
|
|
|
|
res.redirect '/login'
|
|
|
|
|
2014-04-10 13:43:06 +00:00
|
|
|
register : (req, res, next = (error) ->)->
|
|
|
|
logger.log email: req.body.email, "attempted register"
|
|
|
|
redir = Url.parse(req.body.redir or "/project").path
|
|
|
|
UserRegistrationHandler.registerNewUser req.body, (err, user)->
|
|
|
|
if err == "EmailAlreadyRegisterd"
|
|
|
|
return AuthenticationController.login req, res
|
|
|
|
else if err?
|
|
|
|
next(err)
|
|
|
|
else
|
|
|
|
metrics.inc "user.register.success"
|
|
|
|
req.session.user = user
|
|
|
|
req.session.justRegistered = true
|
2014-04-15 12:59:00 +00:00
|
|
|
ReferalAllocator.allocate req.session.referal_id, user._id, req.session.referal_source, req.session.referal_medium
|
2014-04-10 13:43:06 +00:00
|
|
|
res.send
|
|
|
|
redir:redir
|
|
|
|
id:user._id.toString()
|
|
|
|
first_name: user.first_name
|
|
|
|
last_name: user.last_name
|
|
|
|
email: user.email
|
|
|
|
created: Date.now()
|
|
|
|
|
2014-04-15 12:59:00 +00:00
|
|
|
|
2014-04-10 16:15:18 +00:00
|
|
|
changePassword : (req, res, next = (error) ->)->
|
|
|
|
metrics.inc "user.password-change"
|
|
|
|
oldPass = req.body.currentPassword
|
|
|
|
AuthenticationManager.authenticate {_id:req.session.user._id}, oldPass, (err, user)->
|
|
|
|
return next(err) if err?
|
|
|
|
if(user)
|
|
|
|
logger.log user: req.session.user, "changing password"
|
|
|
|
newPassword1 = req.body.newPassword1
|
|
|
|
newPassword2 = req.body.newPassword2
|
|
|
|
if newPassword1 != newPassword2
|
|
|
|
logger.log user: user, "passwords do not match"
|
|
|
|
res.send
|
|
|
|
message:
|
|
|
|
type:'error'
|
|
|
|
text:'Your passwords do not match'
|
|
|
|
else
|
|
|
|
logger.log user: user, "password changed"
|
|
|
|
AuthenticationManager.setUserPassword user._id, newPassword1, (error) ->
|
|
|
|
return next(error) if error?
|
|
|
|
res.send
|
|
|
|
message:
|
|
|
|
type:'success'
|
|
|
|
text:'Your password has been changed'
|
|
|
|
else
|
|
|
|
logger.log user: user, "current password wrong"
|
|
|
|
res.send
|
|
|
|
message:
|
|
|
|
type:'error'
|
2014-05-16 16:45:48 +00:00
|
|
|
text:'Your old password is wrong'
|
|
|
|
|
|
|
|
changeEmailAddress: (req, res)->
|
|
|
|
|
|
|
|
|