mirror of
https://github.com/overleaf/overleaf.git
synced 2025-01-14 12:53:41 +00:00
30 lines
944 B
CoffeeScript
30 lines
944 B
CoffeeScript
sanitize = require('sanitizer')
|
|
|
|
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
|
|
|
|
validateRegisterRequest : (req, callback)->
|
|
email = sanitize.escape(req.body.email).trim().toLowerCase()
|
|
password = req.body.password
|
|
username = email.match(/^[^@]*/)
|
|
if username?
|
|
first_name = username[0]
|
|
else
|
|
first_name = ""
|
|
last_name = ""
|
|
|
|
if @hasZeroLengths([password, email])
|
|
callback('please fill in all the fields', null)
|
|
else if !@validateEmail(email)
|
|
callback('not valid email', null)
|
|
else
|
|
callback(null, {first_name:first_name, last_name:last_name, email:email, password:password})
|