2014-02-12 05:23:40 -05:00
|
|
|
path = require('path')
|
|
|
|
ProjectUploadManager = require('../Uploads/ProjectUploadManager')
|
|
|
|
ProjectOptionsHandler = require("../Project/ProjectOptionsHandler")
|
|
|
|
TemplatesPublisher = require("./TemplatesPublisher")
|
|
|
|
settings = require('settings-sharelatex')
|
|
|
|
fs = require('fs')
|
|
|
|
request = require('request')
|
|
|
|
uuid = require('node-uuid')
|
|
|
|
logger = require('logger-sharelatex')
|
|
|
|
|
|
|
|
|
|
|
|
module.exports =
|
|
|
|
|
|
|
|
createProjectFromZipTemplate: (req, res)->
|
|
|
|
logger.log body:req.session.templateData, "creating project from zip"
|
|
|
|
if !req.session.templateData?
|
|
|
|
return res.redirect "/project"
|
|
|
|
|
|
|
|
dumpPath = "#{settings.path.dumpFolder}/#{uuid.v4()}"
|
|
|
|
writeStream = fs.createWriteStream(dumpPath)
|
|
|
|
zipUrl = req.session.templateData.zipUrl
|
2014-04-11 10:15:32 -04:00
|
|
|
if zipUrl.slice(0,12).indexOf("templates") == -1
|
|
|
|
zipUrl = "#{settings.apis.web.url}#{zipUrl}"
|
|
|
|
else
|
|
|
|
zipUrl = "#{settings.apis.templates_api.url}#{zipUrl}"
|
2014-04-09 03:24:23 -04:00
|
|
|
request(zipUrl).pipe(writeStream)
|
2014-02-12 05:23:40 -05:00
|
|
|
writeStream.on 'close', ->
|
|
|
|
ProjectUploadManager.createProjectFromZipArchive req.session.user._id, req.session.templateData.templateName, dumpPath, (err, project)->
|
2014-04-09 06:45:57 -04:00
|
|
|
if err?
|
|
|
|
logger.err err:err, zipUrl:zipUrl, "problem building project from zip"
|
|
|
|
return res.send 500
|
2014-02-12 05:23:40 -05:00
|
|
|
setCompiler project._id, req.session.templateData.compiler, ->
|
|
|
|
fs.unlink dumpPath, ->
|
|
|
|
delete req.session.templateData
|
|
|
|
res.redirect "/project/#{project._id}"
|
|
|
|
|
|
|
|
publishProject: (user_id, project_id, callback)->
|
|
|
|
logger.log user_id:user_id, project_id:project_id, "reciving request to publish project as template"
|
|
|
|
TemplatesPublisher.publish user_id, project_id, callback
|
|
|
|
|
|
|
|
unPublishProject: (user_id, project_id, callback)->
|
|
|
|
logger.log user_id:user_id, project_id:project_id, "reciving request to unpublish project as template"
|
|
|
|
TemplatesPublisher.unpublish user_id, project_id, callback
|
|
|
|
|
2014-02-27 12:35:35 -05:00
|
|
|
getTemplateDetails: (user_id, project_id, callback)->
|
2014-03-20 08:53:23 -04:00
|
|
|
TemplatesPublisher.getTemplateDetails user_id, project_id, (err, details)->
|
|
|
|
if err?
|
|
|
|
logger.err err:err, user_id:user_id, project_id:project_id, "something went wrong getting template details"
|
|
|
|
callback(err, details)
|
2014-02-27 12:35:35 -05:00
|
|
|
|
|
|
|
|
2014-02-12 05:23:40 -05:00
|
|
|
setCompiler = (project_id, compiler, callback)->
|
|
|
|
if compiler?
|
|
|
|
ProjectOptionsHandler.setCompiler project_id, compiler, callback
|
|
|
|
else
|
|
|
|
callback()
|