mirror of
https://github.com/overleaf/overleaf.git
synced 2024-12-12 02:42:25 -05:00
96 lines
3.3 KiB
CoffeeScript
96 lines
3.3 KiB
CoffeeScript
sanitize = require('sanitizer')
|
|
User = require("../../models/User").User
|
|
UserCreator = require("./UserCreator")
|
|
AuthenticationManager = require("../Authentication/AuthenticationManager")
|
|
NewsLetterManager = require("../Newsletter/NewsletterManager")
|
|
async = require("async")
|
|
logger = require("logger-sharelatex")
|
|
crypto = require("crypto")
|
|
EmailHandler = require("../Email/EmailHandler")
|
|
OneTimeTokenHandler = require "../Security/OneTimeTokenHandler"
|
|
Analytics = require "../Analytics/AnalyticsManager"
|
|
settings = require "settings-sharelatex"
|
|
|
|
module.exports = UserRegistrationHandler =
|
|
validateEmail : (email) ->
|
|
re = /^(([^<>()[\]\\.,;:\s@\"]+(\.[^<>()[\]\\.,;:\s@\"]+)*)|(\ ".+\"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA -Z\-0-9]+\.)+[a-zA-Z]{2,}))$/
|
|
return re.test(email)
|
|
|
|
hasZeroLengths : (props) ->
|
|
hasZeroLength = false
|
|
props.forEach (prop) ->
|
|
if prop.length == 0
|
|
hasZeroLength = true
|
|
return hasZeroLength
|
|
|
|
_registrationRequestIsValid : (body, callback)->
|
|
email = sanitize.escape(body.email).trim().toLowerCase()
|
|
password = body.password
|
|
username = email.match(/^[^@]*/)
|
|
if @hasZeroLengths([password, email])
|
|
return false
|
|
else if !@validateEmail(email)
|
|
return false
|
|
else
|
|
return true
|
|
|
|
_createNewUserIfRequired: (user, userDetails, callback)->
|
|
if !user?
|
|
userDetails.holdingAccount = false
|
|
UserCreator.createNewUser {holdingAccount:false, email:userDetails.email, first_name:userDetails.first_name, last_name:userDetails.last_name}, callback
|
|
else
|
|
callback null, user
|
|
|
|
registerNewUser: (userDetails, callback)->
|
|
self = @
|
|
requestIsValid = @_registrationRequestIsValid userDetails
|
|
if !requestIsValid
|
|
return callback(new Error("request is not valid"))
|
|
userDetails.email = userDetails.email?.trim()?.toLowerCase()
|
|
User.findOne email:userDetails.email, (err, user)->
|
|
if err?
|
|
return callback err
|
|
if user?.holdingAccount == false
|
|
return callback(new Error("EmailAlreadyRegistered"), user)
|
|
self._createNewUserIfRequired user, userDetails, (err, user)->
|
|
if err?
|
|
return callback(err)
|
|
async.series [
|
|
(cb)-> User.update {_id: user._id}, {"$set":{holdingAccount:false}}, cb
|
|
(cb)-> AuthenticationManager.setUserPassword user._id, userDetails.password, cb
|
|
(cb)->
|
|
NewsLetterManager.subscribe user, ->
|
|
cb() #this can be slow, just fire it off
|
|
], (err)->
|
|
logger.log user: user, "registered"
|
|
Analytics.recordEvent user._id, "user-registered"
|
|
callback(err, user)
|
|
|
|
registerNewUserAndSendActivationEmail: (email, callback = (error, user, setNewPasswordUrl) ->) ->
|
|
logger.log {email}, "registering new user"
|
|
UserRegistrationHandler.registerNewUser {
|
|
email: email
|
|
password: crypto.randomBytes(32).toString("hex")
|
|
}, (err, user)->
|
|
if err? and err?.message != "EmailAlreadyRegistered"
|
|
return callback(err)
|
|
|
|
if err?.message == "EmailAlreadyRegistered"
|
|
logger.log {email}, "user already exists, resending welcome email"
|
|
|
|
ONE_WEEK = 7 * 24 * 60 * 60 # seconds
|
|
OneTimeTokenHandler.getNewToken user._id, { expiresIn: ONE_WEEK }, (err, token)->
|
|
return callback(err) if err?
|
|
|
|
setNewPasswordUrl = "#{settings.siteUrl}/user/activate?token=#{token}&user_id=#{user._id}"
|
|
|
|
EmailHandler.sendEmail "registered", {
|
|
to: user.email
|
|
setNewPasswordUrl: setNewPasswordUrl
|
|
}, () ->
|
|
|
|
callback null, user, setNewPasswordUrl
|
|
|
|
|
|
|
|
|