mirror of
https://github.com/overleaf/overleaf.git
synced 2025-01-18 12:21:20 +00:00
e753ef3af5
We'll remove that attribute soon, but for the time being we want users to still be able to join the team.
183 lines
6.9 KiB
CoffeeScript
183 lines
6.9 KiB
CoffeeScript
UserHandler = require("./UserHandler")
|
|
UserDeleter = require("./UserDeleter")
|
|
UserGetter = require("./UserGetter")
|
|
User = require("../../models/User").User
|
|
newsLetterManager = require('../Newsletter/NewsletterManager')
|
|
UserRegistrationHandler = require("./UserRegistrationHandler")
|
|
logger = require("logger-sharelatex")
|
|
metrics = require("metrics-sharelatex")
|
|
Url = require("url")
|
|
AuthenticationManager = require("../Authentication/AuthenticationManager")
|
|
AuthenticationController = require('../Authentication/AuthenticationController')
|
|
UserSessionsManager = require("./UserSessionsManager")
|
|
UserUpdater = require("./UserUpdater")
|
|
SudoModeHandler = require('../SudoMode/SudoModeHandler')
|
|
settings = require "settings-sharelatex"
|
|
|
|
module.exports = UserController =
|
|
|
|
tryDeleteUser: (req, res, next) ->
|
|
user_id = AuthenticationController.getLoggedInUserId(req)
|
|
password = req.body.password
|
|
logger.log {user_id}, "trying to delete user account"
|
|
if !password? or password == ''
|
|
logger.err {user_id}, 'no password supplied for attempt to delete account'
|
|
return res.sendStatus(403)
|
|
AuthenticationManager.authenticate {_id: user_id}, password, (err, user) ->
|
|
if err?
|
|
logger.err {user_id}, 'error authenticating during attempt to delete account'
|
|
return next(err)
|
|
if !user
|
|
logger.err {user_id}, 'auth failed during attempt to delete account'
|
|
return res.sendStatus(403)
|
|
UserDeleter.deleteUser user_id, (err) ->
|
|
if err?
|
|
logger.err {user_id}, "error while deleting user account"
|
|
return next(err)
|
|
sessionId = req.sessionID
|
|
req.logout?()
|
|
req.session.destroy (err) ->
|
|
if err?
|
|
logger.err err: err, 'error destorying session'
|
|
return next(err)
|
|
UserSessionsManager.untrackSession(user, sessionId)
|
|
res.sendStatus(200)
|
|
|
|
unsubscribe: (req, res)->
|
|
user_id = AuthenticationController.getLoggedInUserId(req)
|
|
UserGetter.getUser user_id, (err, user)->
|
|
newsLetterManager.unsubscribe user, ->
|
|
res.send()
|
|
|
|
updateUserSettings : (req, res)->
|
|
user_id = AuthenticationController.getLoggedInUserId(req)
|
|
logger.log user_id: user_id, "updating account settings"
|
|
User.findById user_id, (err, user)->
|
|
if err? or !user?
|
|
logger.err err:err, user_id:user_id, "problem updaing user settings"
|
|
return res.sendStatus 500
|
|
|
|
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()
|
|
if req.body.role?
|
|
user.role = req.body.role.trim()
|
|
if req.body.institution?
|
|
user.institution = req.body.institution.trim()
|
|
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?
|
|
user.ace.autoComplete = req.body.autoComplete
|
|
if req.body.autoPairDelimiters?
|
|
user.ace.autoPairDelimiters = req.body.autoPairDelimiters
|
|
if req.body.spellCheckLanguage?
|
|
user.ace.spellCheckLanguage = req.body.spellCheckLanguage
|
|
if req.body.pdfViewer?
|
|
user.ace.pdfViewer = req.body.pdfViewer
|
|
if req.body.syntaxValidation?
|
|
user.ace.syntaxValidation = req.body.syntaxValidation
|
|
if req.body.fontFamily?
|
|
user.ace.fontFamily = req.body.fontFamily
|
|
if req.body.lineHeight?
|
|
user.ace.lineHeight = req.body.lineHeight
|
|
|
|
user.save (err)->
|
|
newEmail = req.body.email?.trim().toLowerCase()
|
|
if !newEmail? or newEmail == user.email or req.externalAuthenticationSystemUsed()
|
|
# end here, don't update email
|
|
AuthenticationController.setInSessionUser(req, {first_name: user.first_name, last_name: user.last_name})
|
|
return res.sendStatus 200
|
|
else if newEmail.indexOf("@") == -1
|
|
# email invalid
|
|
return res.sendStatus(400)
|
|
else
|
|
# update the user email
|
|
UserUpdater.changeEmailAddress user_id, newEmail, (err)->
|
|
if err?
|
|
logger.err err:err, user_id:user_id, newEmail:newEmail, "problem updaing users email address"
|
|
if err.message == "alread_exists"
|
|
message = req.i18n.translate("email_already_registered")
|
|
else
|
|
message = req.i18n.translate("problem_changing_email_address")
|
|
return res.send 500, {message:message}
|
|
User.findById user_id, (err, user)->
|
|
if err?
|
|
logger.err err:err, user_id:user_id, "error getting user for email update"
|
|
return res.send 500
|
|
AuthenticationController.setInSessionUser(req, {email: user.email, first_name: user.first_name, last_name: user.last_name})
|
|
UserHandler.populateTeamInvites user, (err)-> #need to refresh this in the background
|
|
if err?
|
|
logger.err err:err, "error populateTeamInvites"
|
|
res.sendStatus(200)
|
|
|
|
logout : (req, res)->
|
|
metrics.inc "user.logout"
|
|
user = AuthenticationController.getSessionUser(req)
|
|
logger.log user: user, "logging out"
|
|
sessionId = req.sessionID
|
|
req.logout?() # passport logout
|
|
req.session.destroy (err)->
|
|
if err
|
|
logger.err err: err, 'error destorying session'
|
|
if user?
|
|
UserSessionsManager.untrackSession(user, sessionId)
|
|
SudoModeHandler.clearSudoMode(user._id)
|
|
res.redirect '/login'
|
|
|
|
register : (req, res, next = (error) ->)->
|
|
email = req.body.email
|
|
if !email? or email == ""
|
|
res.sendStatus 422 # Unprocessable Entity
|
|
return
|
|
UserRegistrationHandler.registerNewUserAndSendActivationEmail email, (error, user, setNewPasswordUrl) ->
|
|
return next(error) if error?
|
|
res.json {
|
|
email: user.email
|
|
setNewPasswordUrl: setNewPasswordUrl
|
|
}
|
|
|
|
clearSessions: (req, res, next = (error) ->) ->
|
|
metrics.inc "user.clear-sessions"
|
|
user = AuthenticationController.getSessionUser(req)
|
|
logger.log {user_id: user._id}, "clearing sessions for user"
|
|
UserSessionsManager.revokeAllUserSessions user, [req.sessionID], (err) ->
|
|
return next(err) if err?
|
|
res.sendStatus 201
|
|
|
|
changePassword : (req, res, next = (error) ->)->
|
|
metrics.inc "user.password-change"
|
|
oldPass = req.body.currentPassword
|
|
user_id = AuthenticationController.getLoggedInUserId(req)
|
|
AuthenticationManager.authenticate {_id:user_id}, oldPass, (err, user)->
|
|
return next(err) if err?
|
|
if(user)
|
|
logger.log user: user._id, "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?
|
|
UserSessionsManager.revokeAllUserSessions user, [req.sessionID], (err) ->
|
|
return next(err) if err?
|
|
res.send
|
|
message:
|
|
type:'success'
|
|
text:'Your password has been changed'
|
|
else
|
|
logger.log user_id: user_id, "current password wrong"
|
|
res.send
|
|
message:
|
|
type:'error'
|
|
text:'Your old password is wrong'
|