2014-02-12 17:27:43 +00:00
|
|
|
RequestParser = require "./RequestParser"
|
|
|
|
CompileManager = require "./CompileManager"
|
|
|
|
Settings = require "settings-sharelatex"
|
|
|
|
Metrics = require "./Metrics"
|
|
|
|
ProjectPersistenceManager = require "./ProjectPersistenceManager"
|
|
|
|
logger = require "logger-sharelatex"
|
2017-08-03 14:56:59 +00:00
|
|
|
Errors = require "./Errors"
|
2014-02-12 17:27:43 +00:00
|
|
|
|
|
|
|
module.exports = CompileController =
|
|
|
|
compile: (req, res, next = (error) ->) ->
|
|
|
|
timer = new Metrics.Timer("compile-request")
|
|
|
|
RequestParser.parse req.body, (error, request) ->
|
|
|
|
return next(error) if error?
|
|
|
|
request.project_id = req.params.project_id
|
2016-05-27 14:29:26 +00:00
|
|
|
request.user_id = req.params.user_id if req.params.user_id?
|
2014-02-12 17:27:43 +00:00
|
|
|
ProjectPersistenceManager.markProjectAsJustAccessed request.project_id, (error) ->
|
|
|
|
return next(error) if error?
|
2017-09-22 15:19:33 +00:00
|
|
|
CompileManager.doCompileWithLock request, (error, outputFiles = []) ->
|
|
|
|
if error instanceof Errors.AlreadyCompilingError
|
2017-09-25 15:06:45 +00:00
|
|
|
code = 423 # Http 423 Locked
|
2017-09-22 15:19:33 +00:00
|
|
|
status = "compile-in-progress"
|
|
|
|
else if error instanceof Errors.FilesOutOfSyncError
|
2017-08-01 13:35:55 +00:00
|
|
|
code = 409 # Http 409 Conflict
|
|
|
|
status = "retry"
|
|
|
|
else if error?.terminated
|
2016-07-14 13:47:36 +00:00
|
|
|
status = "terminated"
|
2016-07-27 15:54:27 +00:00
|
|
|
else if error?.validate
|
|
|
|
status = "validation-#{error.validate}"
|
2016-07-14 13:47:36 +00:00
|
|
|
else if error?
|
2014-05-19 11:18:57 +00:00
|
|
|
if error.timedout
|
|
|
|
status = "timedout"
|
2017-05-24 08:41:26 +00:00
|
|
|
logger.log err: error, project_id: request.project_id, "timeout running compile"
|
2014-05-19 11:18:57 +00:00
|
|
|
else
|
|
|
|
status = "error"
|
|
|
|
code = 500
|
2018-11-23 14:52:13 +00:00
|
|
|
logger.warn err: error, project_id: request.project_id, "error running compile"
|
2018-02-13 12:05:10 +00:00
|
|
|
|
2014-02-12 17:27:43 +00:00
|
|
|
else
|
|
|
|
status = "failure"
|
|
|
|
for file in outputFiles
|
2014-05-29 14:49:48 +00:00
|
|
|
if file.path?.match(/output\.pdf$/)
|
2014-02-12 17:27:43 +00:00
|
|
|
status = "success"
|
2018-03-02 18:31:09 +00:00
|
|
|
|
2018-02-13 12:05:10 +00:00
|
|
|
if status == "failure"
|
2018-11-23 14:52:13 +00:00
|
|
|
logger.warn project_id: request.project_id, outputFiles:outputFiles, "project failed to compile successfully, no output.pdf generated"
|
2014-02-12 17:27:43 +00:00
|
|
|
|
2018-01-03 15:41:31 +00:00
|
|
|
# log an error if any core files are found
|
|
|
|
for file in outputFiles
|
|
|
|
if file.path is "core"
|
|
|
|
logger.error project_id:request.project_id, req:req, outputFiles:outputFiles, "core file found in output"
|
2014-02-12 17:27:43 +00:00
|
|
|
|
|
|
|
timer.done()
|
2015-05-12 10:40:29 +00:00
|
|
|
res.status(code or 200).send {
|
2014-02-12 17:27:43 +00:00
|
|
|
compile:
|
|
|
|
status: status
|
2014-05-19 11:18:57 +00:00
|
|
|
error: error?.message or error
|
2014-02-12 17:27:43 +00:00
|
|
|
outputFiles: outputFiles.map (file) ->
|
2016-05-27 14:25:13 +00:00
|
|
|
url:
|
|
|
|
"#{Settings.apis.clsi.url}/project/#{request.project_id}" +
|
2016-05-27 14:29:26 +00:00
|
|
|
(if request.user_id? then "/user/#{request.user_id}" else "") +
|
2016-05-27 14:25:13 +00:00
|
|
|
(if file.build? then "/build/#{file.build}" else "") +
|
|
|
|
"/output/#{file.path}"
|
2016-05-19 15:23:07 +00:00
|
|
|
path: file.path
|
2014-02-12 17:27:43 +00:00
|
|
|
type: file.type
|
2015-02-25 17:05:19 +00:00
|
|
|
build: file.build
|
2014-02-12 17:27:43 +00:00
|
|
|
}
|
2016-07-14 13:47:36 +00:00
|
|
|
|
|
|
|
stopCompile: (req, res, next) ->
|
2016-07-18 10:05:45 +00:00
|
|
|
{project_id, user_id} = req.params
|
2016-07-14 13:47:36 +00:00
|
|
|
CompileManager.stopCompile project_id, user_id, (error) ->
|
|
|
|
return next(error) if error?
|
|
|
|
res.sendStatus(204)
|
|
|
|
|
2014-02-12 17:27:43 +00:00
|
|
|
clearCache: (req, res, next = (error) ->) ->
|
2016-05-27 14:31:44 +00:00
|
|
|
ProjectPersistenceManager.clearProject req.params.project_id, req.params.user_id, (error) ->
|
2014-02-12 17:27:43 +00:00
|
|
|
return next(error) if error?
|
2015-05-12 10:40:29 +00:00
|
|
|
res.sendStatus(204) # No content
|
2014-04-08 14:18:56 +00:00
|
|
|
|
|
|
|
syncFromCode: (req, res, next = (error) ->) ->
|
|
|
|
file = req.query.file
|
|
|
|
line = parseInt(req.query.line, 10)
|
|
|
|
column = parseInt(req.query.column, 10)
|
|
|
|
project_id = req.params.project_id
|
2016-05-27 14:29:26 +00:00
|
|
|
user_id = req.params.user_id
|
|
|
|
CompileManager.syncFromCode project_id, user_id, file, line, column, (error, pdfPositions) ->
|
2014-04-08 14:18:56 +00:00
|
|
|
return next(error) if error?
|
2019-02-12 16:54:59 +00:00
|
|
|
res.json {
|
2014-04-08 14:18:56 +00:00
|
|
|
pdf: pdfPositions
|
|
|
|
}
|
|
|
|
|
|
|
|
syncFromPdf: (req, res, next = (error) ->) ->
|
|
|
|
page = parseInt(req.query.page, 10)
|
|
|
|
h = parseFloat(req.query.h)
|
|
|
|
v = parseFloat(req.query.v)
|
|
|
|
project_id = req.params.project_id
|
2016-05-27 14:29:26 +00:00
|
|
|
user_id = req.params.user_id
|
|
|
|
CompileManager.syncFromPdf project_id, user_id, page, h, v, (error, codePositions) ->
|
2014-04-08 14:18:56 +00:00
|
|
|
return next(error) if error?
|
2019-02-12 16:54:59 +00:00
|
|
|
res.json {
|
2014-04-08 14:18:56 +00:00
|
|
|
code: codePositions
|
|
|
|
}
|
2015-06-08 21:35:24 +00:00
|
|
|
|
|
|
|
wordcount: (req, res, next = (error) ->) ->
|
2015-09-09 11:43:32 +00:00
|
|
|
file = req.query.file || "main.tex"
|
2015-06-08 21:35:24 +00:00
|
|
|
project_id = req.params.project_id
|
2016-05-27 14:29:26 +00:00
|
|
|
user_id = req.params.user_id
|
2016-01-19 14:12:41 +00:00
|
|
|
image = req.query.image
|
|
|
|
logger.log {image, file, project_id}, "word count request"
|
2015-06-08 21:35:24 +00:00
|
|
|
|
2016-05-27 14:29:26 +00:00
|
|
|
CompileManager.wordcount project_id, user_id, file, image, (error, result) ->
|
2015-06-08 21:35:24 +00:00
|
|
|
return next(error) if error?
|
2019-02-12 16:54:59 +00:00
|
|
|
res.json {
|
2015-06-08 21:35:24 +00:00
|
|
|
texcount: result
|
|
|
|
}
|
2016-04-20 14:38:05 +00:00
|
|
|
|
|
|
|
status: (req, res, next = (error)-> )->
|
|
|
|
res.send("OK")
|
|
|
|
|