2014-03-31 15:46:28 +00:00
sanitize = require ( ' sanitizer ' )
2014-04-10 13:43:06 +00:00
User = require ( " ../../models/User " ) . User
UserCreator = require ( " ./UserCreator " )
AuthenticationManager = require ( " ../Authentication/AuthenticationManager " )
2014-04-10 21:21:20 +00:00
NewsLetterManager = require ( " ../Newsletter/NewsletterManager " )
2014-04-10 13:43:06 +00:00
async = require ( " async " )
logger = require ( " logger-sharelatex " )
2014-02-12 10:23:40 +00:00
module.exports =
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
2014-04-10 13:43:06 +00:00
_registrationRequestIsValid : (body, callback)->
email = sanitize . escape ( body . email ) . trim ( ) . toLowerCase ( )
password = body . password
2014-02-12 10:23:40 +00:00
username = email . match ( /^[^@]*/ )
if @ hasZeroLengths ( [ password , email ] )
2014-04-10 13:43:06 +00:00
return false
2014-02-12 10:23:40 +00:00
else if ! @ validateEmail ( email )
2014-04-10 13:43:06 +00:00
return false
2014-02-12 10:23:40 +00:00
else
2014-04-10 13:43:06 +00:00
return true
2014-04-10 11:39:13 +00:00
2014-04-10 13:43:06 +00:00
_createNewUserIfRequired: (user, userDetails, callback)->
if ! user ?
UserCreator . createNewUser { holdingAccount : false , email : userDetails . email } , callback
else
callback null , user
2014-04-10 11:39:13 +00:00
registerNewUser: (userDetails, callback)->
2014-04-10 13:43:06 +00:00
self = @
requestIsValid = @ _registrationRequestIsValid userDetails
if ! requestIsValid
2015-03-18 16:19:48 +00:00
return callback ( new Error ( " request is not valid " ) )
2014-04-10 13:43:06 +00:00
userDetails.email = userDetails . email ? . trim ( ) ? . toLowerCase ( )
User . findOne email : userDetails . email , (err, user)->
if err ?
return callback err
if user ? . holdingAccount == false
2015-03-19 14:22:48 +00:00
return callback ( new Error ( " EmailAlreadyRegistered " ) , user )
2014-04-10 13:43:06 +00:00
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
2015-02-23 16:03:45 +00:00
(cb)->
NewsLetterManager . subscribe user , ->
cb ( ) #this can be slow, just fire it off
2014-04-10 13:43:06 +00:00
] , (err)->
logger . log user: user , " registered "
callback ( err , user )
2014-04-10 11:39:13 +00:00