2014-02-12 10:23:40 +00:00
|
|
|
User = require("../../models/User").User
|
2016-06-13 12:21:44 +00:00
|
|
|
logger = require("logger-sharelatex")
|
2017-04-03 15:18:30 +00:00
|
|
|
metrics = require('metrics-sharelatex')
|
2018-07-04 13:12:54 +00:00
|
|
|
{ addAffiliation } = require("./UserAffiliationsManager")
|
2014-02-12 10:23:40 +00:00
|
|
|
|
2017-03-17 14:55:41 +00:00
|
|
|
|
|
|
|
module.exports = UserCreator =
|
2014-02-12 10:23:40 +00:00
|
|
|
|
|
|
|
createNewUser: (opts, callback)->
|
2016-06-13 12:21:44 +00:00
|
|
|
logger.log opts:opts, "creating new user"
|
2014-02-12 10:23:40 +00:00
|
|
|
user = new User()
|
2014-04-10 13:43:06 +00:00
|
|
|
|
|
|
|
username = opts.email.match(/^[^@]*/)
|
2017-08-07 10:24:04 +00:00
|
|
|
if !opts.first_name? or opts.first_name == ""
|
|
|
|
opts.first_name = username[0]
|
2014-04-10 13:43:06 +00:00
|
|
|
|
2017-08-07 10:24:04 +00:00
|
|
|
for key, value of opts
|
|
|
|
user[key] = value
|
|
|
|
|
|
|
|
user.ace.syntaxValidation = true
|
2015-01-21 15:26:01 +00:00
|
|
|
user.featureSwitches?.pdfng = true
|
2018-05-28 14:08:37 +00:00
|
|
|
user.emails = [
|
|
|
|
email: user.email
|
|
|
|
createdAt: new Date()
|
|
|
|
]
|
2014-04-10 13:43:06 +00:00
|
|
|
|
2014-02-12 10:23:40 +00:00
|
|
|
user.save (err)->
|
|
|
|
callback(err, user)
|
2017-03-17 14:55:41 +00:00
|
|
|
|
2018-07-04 13:12:54 +00:00
|
|
|
# call addaffiliation after the main callback so it runs in the
|
|
|
|
# background. There is no guaranty this will run so we must no rely on it
|
|
|
|
addAffiliation user._id, user.email, (error) ->
|
|
|
|
if error
|
|
|
|
logger.log { userId: user._id, email: user.email, error: error },
|
|
|
|
"couldn't add affiliation for user on create"
|
|
|
|
else
|
|
|
|
logger.log { userId: user._id, email: user.email },
|
|
|
|
"added affiliation for user on create"
|
|
|
|
|
|
|
|
|
2017-03-17 14:55:41 +00:00
|
|
|
metrics.timeAsyncMethod(
|
|
|
|
UserCreator, 'createNewUser',
|
|
|
|
'mongo.UserCreator',
|
|
|
|
logger
|
|
|
|
)
|