2014-02-12 10:23:40 +00:00
|
|
|
Metrics = require "../../infrastructure/Metrics"
|
|
|
|
Project = require("../../models/Project").Project
|
|
|
|
CompileManager = require("./CompileManager")
|
2014-05-19 15:10:41 +00:00
|
|
|
ClsiManager = require("./ClsiManager")
|
2014-02-12 10:23:40 +00:00
|
|
|
logger = require "logger-sharelatex"
|
|
|
|
request = require "request"
|
|
|
|
Settings = require "settings-sharelatex"
|
2014-05-19 14:28:35 +00:00
|
|
|
AuthenticationController = require "../Authentication/AuthenticationController"
|
2014-10-16 15:34:21 +00:00
|
|
|
UserGetter = require "../User/UserGetter"
|
2014-02-12 10:23:40 +00:00
|
|
|
|
|
|
|
module.exports = CompileController =
|
2014-05-19 14:28:35 +00:00
|
|
|
compile: (req, res, next = (error) ->) ->
|
2014-10-17 12:23:29 +00:00
|
|
|
res.setTimeout(5 * 60 * 1000)
|
2014-05-19 14:28:35 +00:00
|
|
|
project_id = req.params.Project_id
|
|
|
|
isAutoCompile = !!req.query?.auto_compile
|
2014-06-01 16:16:05 +00:00
|
|
|
settingsOverride = req.body?.settingsOverride ? {};
|
2014-06-01 14:43:52 +00:00
|
|
|
logger.log "root doc overriden" if settingsOverride.rootDoc_id?
|
2014-05-19 14:28:35 +00:00
|
|
|
AuthenticationController.getLoggedInUserId req, (error, user_id) ->
|
|
|
|
return next(error) if error?
|
2014-10-16 15:34:21 +00:00
|
|
|
UserGetter.getUser user_id, {"features.compileGroup":1, "features.compileTimeout":1}, (err, user)->
|
2014-11-10 11:26:40 +00:00
|
|
|
settingsOverride.timeout = user?.features?.compileTimeout || Settings.defaultFeatures.compileTimeout
|
|
|
|
settingsOverride.compiler = user?.features?.compileGroup || Settings.defaultFeatures.compileGroup
|
2014-10-21 08:34:58 +00:00
|
|
|
req.session.compileGroup = settingsOverride.compiler
|
2014-10-16 15:34:21 +00:00
|
|
|
CompileManager.compile project_id, user_id, { isAutoCompile, settingsOverride }, (error, status, outputFiles) ->
|
|
|
|
return next(error) if error?
|
|
|
|
res.contentType("application/json")
|
|
|
|
res.send 200, JSON.stringify {
|
|
|
|
status: status
|
|
|
|
outputFiles: outputFiles
|
|
|
|
}
|
2014-05-19 14:28:35 +00:00
|
|
|
|
2014-02-12 10:23:40 +00:00
|
|
|
downloadPdf: (req, res, next = (error) ->)->
|
|
|
|
Metrics.inc "pdf-downloads"
|
|
|
|
project_id = req.params.Project_id
|
|
|
|
Project.findById project_id, {name: 1}, (err, project)->
|
|
|
|
res.contentType("application/pdf")
|
|
|
|
if !!req.query.popupDownload
|
|
|
|
logger.log project_id: project_id, "download pdf as popup download"
|
|
|
|
res.header('Content-Disposition', "attachment; filename=#{project.getSafeProjectName()}.pdf")
|
|
|
|
else
|
|
|
|
logger.log project_id: project_id, "download pdf to embed in browser"
|
|
|
|
res.header('Content-Disposition', "filename=#{project.getSafeProjectName()}.pdf")
|
|
|
|
CompileController.proxyToClsi("/project/#{project_id}/output/output.pdf", req, res, next)
|
|
|
|
|
2014-03-27 17:00:41 +00:00
|
|
|
deleteAuxFiles: (req, res, next) ->
|
|
|
|
project_id = req.params.Project_id
|
2014-05-19 15:10:41 +00:00
|
|
|
ClsiManager.deleteAuxFiles project_id, (error) ->
|
|
|
|
return next(error) if error?
|
|
|
|
res.send(200)
|
2014-02-12 10:23:40 +00:00
|
|
|
|
|
|
|
compileAndDownloadPdf: (req, res, next)->
|
|
|
|
project_id = req.params.project_id
|
|
|
|
CompileManager.compile project_id, null, {}, (err)->
|
|
|
|
if err?
|
|
|
|
logger.err err:err, project_id:project_id, "something went wrong compile and downloading pdf"
|
|
|
|
res.send 500
|
|
|
|
url = "/project/#{project_id}/output/output.pdf"
|
|
|
|
CompileController.proxyToClsi url, req, res, next
|
|
|
|
|
|
|
|
getFileFromClsi: (req, res, next = (error) ->) ->
|
|
|
|
CompileController.proxyToClsi("/project/#{req.params.Project_id}/output/#{req.params.file}", req, res, next)
|
|
|
|
|
2014-04-08 15:49:21 +00:00
|
|
|
proxySync: (req, res, next = (error) ->) ->
|
|
|
|
CompileController.proxyToClsi(req.url, req, res, next)
|
|
|
|
|
2014-02-12 10:23:40 +00:00
|
|
|
proxyToClsi: (url, req, res, next = (error) ->) ->
|
2014-10-21 08:34:58 +00:00
|
|
|
if req.session.compileGroup == "priority"
|
|
|
|
compilerUrl = Settings.apis.clsi_priority.url
|
|
|
|
else
|
|
|
|
compilerUrl = Settings.apis.clsi.url
|
|
|
|
url = "#{compilerUrl}#{url}"
|
2014-10-21 12:48:46 +00:00
|
|
|
logger.log url: url, "proxying to CLSI"
|
2014-10-21 08:16:23 +00:00
|
|
|
oneMinute = 60 * 1000
|
|
|
|
proxy = request(url: url, method: req.method, timeout: oneMinute)
|
|
|
|
proxy.pipe(res)
|
|
|
|
proxy.on "error", (error) ->
|
|
|
|
logger.warn err: error, url: url, "CLSI proxy error"
|
2014-10-21 08:34:58 +00:00
|
|
|
|
2014-10-21 08:16:23 +00:00
|
|
|
|