overleaf/services/web/app/coffee/Features/PasswordReset/PasswordResetHandler.coffee

33 lines
1.3 KiB
CoffeeScript
Raw Normal View History

2014-05-15 15:20:23 +00:00
settings = require("settings-sharelatex")
async = require("async")
UserGetter = require("../User/UserGetter")
PasswordResetTokenHandler = require("./PasswordResetTokenHandler")
2014-05-15 15:20:23 +00:00
EmailHandler = require("../Email/EmailHandler")
AuthenticationManager = require("../Authentication/AuthenticationManager")
2014-05-15 17:08:21 +00:00
logger = require("logger-sharelatex")
2014-05-15 15:20:23 +00:00
module.exports =
generateAndEmailResetToken:(email, callback = (error, exists) ->)->
2014-05-15 15:50:38 +00:00
UserGetter.getUser email:email, (err, user)->
2014-05-15 15:20:23 +00:00
if err then return callback(err)
2014-05-15 15:50:38 +00:00
if !user?
2014-05-15 17:08:21 +00:00
logger.err email:email, "user could not be found for password reset"
return callback(null, false)
PasswordResetTokenHandler.getNewToken user._id, (err, token)->
2014-05-15 15:50:38 +00:00
if err then return callback(err)
emailOptions =
to : email
2014-05-15 16:58:25 +00:00
setNewPasswordUrl : "#{settings.siteUrl}/user/password/set?passwordResetToken=#{token}"
EmailHandler.sendEmail "passwordResetRequested", emailOptions, (error) ->
return callback(error) if error?
callback null, true
2014-05-15 15:20:23 +00:00
setNewUserPassword: (token, password, callback = (error, found) ->)->
PasswordResetTokenHandler.getUserIdFromTokenAndExpire token, (err, user_id)->
2014-05-15 15:20:23 +00:00
if err then return callback(err)
if !user_id?
return callback null, false
AuthenticationManager.setUserPassword user_id, password, (err) ->
if err then return callback(err)
callback null, true