2014-02-12 10:23:40 +00:00
|
|
|
logger = require('logger-sharelatex')
|
|
|
|
async = require("async")
|
2017-04-03 15:18:30 +00:00
|
|
|
metrics = require('metrics-sharelatex')
|
2014-02-12 10:23:40 +00:00
|
|
|
Settings = require('settings-sharelatex')
|
2017-10-24 10:48:21 +00:00
|
|
|
ObjectId = require('mongoose').Types.ObjectId
|
2014-02-12 10:23:40 +00:00
|
|
|
Project = require('../../models/Project').Project
|
|
|
|
Folder = require('../../models/Folder').Folder
|
2018-02-01 15:31:42 +00:00
|
|
|
ProjectEntityUpdateHandler = require('./ProjectEntityUpdateHandler')
|
2017-05-19 15:21:02 +00:00
|
|
|
ProjectDetailsHandler = require('./ProjectDetailsHandler')
|
2017-12-18 16:39:27 +00:00
|
|
|
HistoryManager = require('../History/HistoryManager')
|
2014-02-12 10:23:40 +00:00
|
|
|
User = require('../../models/User').User
|
|
|
|
fs = require('fs')
|
|
|
|
Path = require "path"
|
|
|
|
_ = require "underscore"
|
2018-02-22 21:22:55 +00:00
|
|
|
AnalyticsManger = require("../Analytics/AnalyticsManager")
|
2014-02-12 10:23:40 +00:00
|
|
|
|
2017-03-17 14:55:41 +00:00
|
|
|
module.exports = ProjectCreationHandler =
|
|
|
|
|
2018-05-10 10:39:23 +00:00
|
|
|
createBlankProject : (owner_id, projectName, attributes, callback = (error, project) ->)->
|
2014-02-12 10:23:40 +00:00
|
|
|
metrics.inc("project-creation")
|
2017-10-27 13:56:16 +00:00
|
|
|
if arguments.length == 3
|
2018-05-10 10:39:23 +00:00
|
|
|
callback = attributes
|
|
|
|
attributes = null
|
2017-10-27 13:56:16 +00:00
|
|
|
|
2017-05-19 15:21:02 +00:00
|
|
|
ProjectDetailsHandler.validateProjectName projectName, (error) ->
|
|
|
|
return callback(error) if error?
|
|
|
|
logger.log owner_id:owner_id, projectName:projectName, "creating blank project"
|
2018-05-10 10:39:23 +00:00
|
|
|
if attributes?
|
|
|
|
ProjectCreationHandler._createBlankProject owner_id, projectName, attributes, (error, project) ->
|
2018-03-06 23:26:25 +00:00
|
|
|
return callback(error) if error?
|
|
|
|
AnalyticsManger.recordEvent(
|
2018-05-10 10:39:23 +00:00
|
|
|
owner_id, 'project-imported', { projectId: project._id, attributes: attributes }
|
2018-03-06 23:26:25 +00:00
|
|
|
)
|
|
|
|
callback(error, project)
|
2017-10-27 13:56:16 +00:00
|
|
|
else
|
2017-12-18 16:39:27 +00:00
|
|
|
HistoryManager.initializeProject (error, history) ->
|
2017-10-27 13:56:16 +00:00
|
|
|
return callback(error) if error?
|
2018-05-10 10:39:23 +00:00
|
|
|
attributes = overleaf: history: id: history?.overleaf_id
|
|
|
|
ProjectCreationHandler._createBlankProject owner_id, projectName, attributes, (error, project) ->
|
2018-03-06 23:26:25 +00:00
|
|
|
return callback(error) if error?
|
|
|
|
AnalyticsManger.recordEvent(
|
|
|
|
owner_id, 'project-created', { projectId: project._id }
|
|
|
|
)
|
|
|
|
callback(error, project)
|
2017-10-27 13:56:16 +00:00
|
|
|
|
2018-05-10 10:39:23 +00:00
|
|
|
_createBlankProject : (owner_id, projectName, attributes, callback = (error, project) ->)->
|
2017-10-27 13:56:16 +00:00
|
|
|
rootFolder = new Folder {'name':'rootFolder'}
|
2018-05-10 10:39:23 +00:00
|
|
|
|
|
|
|
attributes.owner_ref = new ObjectId(owner_id)
|
|
|
|
attributes.name = projectName
|
|
|
|
project = new Project attributes
|
|
|
|
|
|
|
|
Object.assign(project, attributes)
|
|
|
|
|
2018-01-03 16:29:28 +00:00
|
|
|
if Settings.apis?.project_history?.displayHistoryForNewProjects
|
|
|
|
project.overleaf.history.display = true
|
2017-10-27 13:56:16 +00:00
|
|
|
if Settings.currentImageName?
|
2018-08-06 15:56:44 +00:00
|
|
|
# avoid clobbering any imageName already set in attributes (e.g. importedImageName)
|
|
|
|
project.imageName ?= Settings.currentImageName
|
2017-10-27 13:56:16 +00:00
|
|
|
project.rootFolder[0] = rootFolder
|
|
|
|
User.findById owner_id, "ace.spellCheckLanguage", (err, user)->
|
|
|
|
project.spellCheckLanguage = user.ace.spellCheckLanguage
|
|
|
|
project.save (err)->
|
|
|
|
return callback(err) if err?
|
|
|
|
callback err, project
|
2014-02-12 10:23:40 +00:00
|
|
|
|
|
|
|
createBasicProject : (owner_id, projectName, callback = (error, project) ->)->
|
|
|
|
self = @
|
|
|
|
@createBlankProject owner_id, projectName, (error, project)->
|
|
|
|
return callback(error) if error?
|
|
|
|
self._buildTemplate "mainbasic.tex", owner_id, projectName, (error, docLines)->
|
|
|
|
return callback(error) if error?
|
2018-02-01 15:31:42 +00:00
|
|
|
ProjectEntityUpdateHandler.addDoc project._id, project.rootFolder[0]._id, "main.tex", docLines, owner_id, (error, doc)->
|
2016-02-29 13:05:17 +00:00
|
|
|
if error?
|
2016-02-29 17:34:38 +00:00
|
|
|
logger.err err:error, "error adding doc when creating basic project"
|
2016-02-29 13:05:17 +00:00
|
|
|
return callback(error)
|
2018-02-01 15:31:42 +00:00
|
|
|
ProjectEntityUpdateHandler.setRootDoc project._id, doc._id, (error) ->
|
2014-02-12 10:23:40 +00:00
|
|
|
callback(error, project)
|
|
|
|
|
|
|
|
createExampleProject: (owner_id, projectName, callback = (error, project) ->)->
|
|
|
|
self = @
|
|
|
|
@createBlankProject owner_id, projectName, (error, project)->
|
|
|
|
return callback(error) if error?
|
|
|
|
async.series [
|
|
|
|
(callback) ->
|
|
|
|
self._buildTemplate "main.tex", owner_id, projectName, (error, docLines)->
|
|
|
|
return callback(error) if error?
|
2018-02-01 15:31:42 +00:00
|
|
|
ProjectEntityUpdateHandler.addDoc project._id, project.rootFolder[0]._id, "main.tex", docLines, owner_id, (error, doc)->
|
2014-02-12 10:23:40 +00:00
|
|
|
return callback(error) if error?
|
2018-02-01 15:31:42 +00:00
|
|
|
ProjectEntityUpdateHandler.setRootDoc project._id, doc._id, callback
|
2014-02-12 10:23:40 +00:00
|
|
|
(callback) ->
|
|
|
|
self._buildTemplate "references.bib", owner_id, projectName, (error, docLines)->
|
|
|
|
return callback(error) if error?
|
2018-02-01 15:31:42 +00:00
|
|
|
ProjectEntityUpdateHandler.addDoc project._id, project.rootFolder[0]._id, "references.bib", docLines, owner_id, (error, doc)->
|
2014-02-12 10:23:40 +00:00
|
|
|
callback(error)
|
|
|
|
(callback) ->
|
|
|
|
universePath = Path.resolve(__dirname + "/../../../templates/project_files/universe.jpg")
|
2018-02-14 15:12:46 +00:00
|
|
|
ProjectEntityUpdateHandler.addFile project._id, project.rootFolder[0]._id, "universe.jpg", universePath, null, owner_id, callback
|
2014-02-12 10:23:40 +00:00
|
|
|
], (error) ->
|
|
|
|
callback(error, project)
|
|
|
|
|
|
|
|
_buildTemplate: (template_name, user_id, project_name, callback = (error, output) ->)->
|
|
|
|
User.findById user_id, "first_name last_name", (error, user)->
|
|
|
|
return callback(error) if error?
|
|
|
|
monthNames = [ "January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December" ]
|
|
|
|
|
|
|
|
templatePath = Path.resolve(__dirname + "/../../../templates/project_files/#{template_name}")
|
|
|
|
fs.readFile templatePath, (error, template) ->
|
|
|
|
return callback(error) if error?
|
|
|
|
data =
|
|
|
|
project_name: project_name
|
|
|
|
user: user
|
|
|
|
year: new Date().getUTCFullYear()
|
|
|
|
month: monthNames[new Date().getUTCMonth()]
|
|
|
|
output = _.template(template.toString(), data)
|
|
|
|
callback null, output.split("\n")
|
|
|
|
|
2017-03-17 14:55:41 +00:00
|
|
|
metrics.timeAsyncMethod(
|
|
|
|
ProjectCreationHandler, 'createBlankProject',
|
|
|
|
'mongo.ProjectCreationHandler',
|
|
|
|
logger
|
|
|
|
)
|
2014-02-12 10:23:40 +00:00
|
|
|
|
|
|
|
|