2014-02-12 05:23:40 -05:00
|
|
|
projectCreationHandler = require('./ProjectCreationHandler')
|
|
|
|
projectEntityHandler = require('./ProjectEntityHandler')
|
|
|
|
projectLocator = require('./ProjectLocator')
|
|
|
|
projectOptionsHandler = require('./ProjectOptionsHandler')
|
|
|
|
DocumentUpdaterHandler = require("../DocumentUpdater/DocumentUpdaterHandler")
|
2014-05-06 07:36:00 -04:00
|
|
|
DocstoreManager = require "../Docstore/DocstoreManager"
|
2016-02-26 03:32:00 -05:00
|
|
|
ProjectGetter = require("./ProjectGetter")
|
2014-02-12 05:23:40 -05:00
|
|
|
_ = require('underscore')
|
|
|
|
async = require('async')
|
2016-03-02 12:34:21 -05:00
|
|
|
logger = require("logger-sharelatex")
|
|
|
|
|
2014-02-12 05:23:40 -05:00
|
|
|
|
2016-03-10 06:58:05 -05:00
|
|
|
module.exports = ProjectDuplicator =
|
|
|
|
|
|
|
|
_copyDocs: (newProject, originalRootDoc, originalFolder, desFolder, docContents, callback)->
|
|
|
|
console.log "_copyDocs", originalRootDoc
|
|
|
|
setRootDoc = _.once (doc_id)->
|
|
|
|
projectEntityHandler.setRootDoc newProject, doc_id
|
|
|
|
|
|
|
|
jobs = originalFolder.docs.map (doc)->
|
|
|
|
return (callback)->
|
|
|
|
content = docContents[doc._id.toString()]
|
|
|
|
projectEntityHandler.addDocWithProject newProject, desFolder._id, doc.name, content.lines, (err, newDoc)->
|
|
|
|
if err?
|
|
|
|
logger.err err:err, "error copying doc"
|
|
|
|
return callback(err)
|
|
|
|
if originalRootDoc? and newDoc.name == originalRootDoc.name
|
|
|
|
setRootDoc newDoc._id
|
|
|
|
callback()
|
|
|
|
|
|
|
|
async.series jobs, callback
|
|
|
|
|
|
|
|
_copyFiles: (newProject, originalProject_id, originalFolder, desFolder, callback)->
|
|
|
|
jobs = originalFolder.fileRefs.map (file)->
|
|
|
|
return (cb)->
|
|
|
|
projectEntityHandler.copyFileFromExistingProjectWithProject newProject, desFolder._id, originalProject_id, file, cb
|
|
|
|
async.series jobs, callback
|
|
|
|
|
|
|
|
|
|
|
|
_copyFolder: (newProject, originalProject_id, originalRootDoc, originalFolder, desFolder, docContents, callback)->
|
|
|
|
ProjectGetter.getProject newProject._id, {rootFolder:true, name:true}, (err, newProject)->
|
|
|
|
if err?
|
|
|
|
logger.err project_id:newProject?._id, "could not get project"
|
|
|
|
return cb(err)
|
|
|
|
|
|
|
|
jobs = originalFolder.folders.map (childFolder)->
|
|
|
|
return (cb)->
|
|
|
|
projectEntityHandler.addFolderWithProject newProject, desFolder?._id, childFolder.name, (err, newFolder)->
|
|
|
|
return cb(err) if err?
|
|
|
|
ProjectDuplicator._copyFolder newProject, originalProject_id, originalRootDoc, childFolder, newFolder, docContents, cb
|
|
|
|
|
|
|
|
jobs.push (cb)->
|
|
|
|
ProjectDuplicator._copyFiles newProject, originalProject_id, originalFolder, desFolder, cb
|
|
|
|
jobs.push (cb)->
|
|
|
|
ProjectDuplicator._copyDocs newProject, originalRootDoc, originalFolder, desFolder, docContents, cb
|
|
|
|
|
|
|
|
async.series jobs, callback
|
|
|
|
|
|
|
|
|
|
|
|
duplicate: (owner, originalProject_id, newProjectName, callback)->
|
|
|
|
|
|
|
|
jobs =
|
|
|
|
flush: (cb)->
|
|
|
|
DocumentUpdaterHandler.flushProjectToMongo originalProject_id, cb
|
|
|
|
originalProject: (cb)->
|
|
|
|
ProjectGetter.getProject originalProject_id, {compiler:true, rootFolder:true, rootDoc_id:true}, cb
|
|
|
|
newProject: (cb)->
|
|
|
|
projectCreationHandler.createBlankProject owner._id, newProjectName, cb
|
|
|
|
originalRootDoc: (cb)->
|
|
|
|
projectLocator.findRootDoc {project_id:originalProject_id}, cb
|
|
|
|
docContentsArray: (cb)->
|
|
|
|
DocstoreManager.getAllDocs originalProject_id, cb
|
|
|
|
|
|
|
|
async.series jobs, (err, results)->
|
|
|
|
if err?
|
|
|
|
logger.err err:err, originalProject_id:originalProject_id, "error duplicating project"
|
|
|
|
return callback(err)
|
|
|
|
{originalProject, newProject, originalRootDoc, docContentsArray} = results
|
|
|
|
originalRootDoc = originalRootDoc[0] #wtf array?
|
|
|
|
docContents = {}
|
|
|
|
for docContent in docContentsArray
|
|
|
|
docContents[docContent._id] = docContent
|
|
|
|
|
|
|
|
projectOptionsHandler.setCompiler newProject._id, originalProject.compiler, ->
|
|
|
|
console.log originalProject.rootFolder, "originalProject"
|
|
|
|
ProjectDuplicator._copyFolder newProject, originalProject_id, originalRootDoc, originalProject.rootFolder[0], newProject.rootFolder[0], docContents, ->
|
|
|
|
if err?
|
|
|
|
logger.err err:err, originalProject_id:originalProject_id, newProjectName:newProjectName, "error cloning project"
|
|
|
|
|
|
|
|
ProjectGetter.getProject newProject._id, {rootFolder:true, name:true}, (err, project)->
|
|
|
|
if err?
|
|
|
|
logger.err err:err, "could not get project for clone"
|
|
|
|
return callback(err)
|
|
|
|
callback(err, newProject)
|
2014-02-12 05:23:40 -05:00
|
|
|
|