2014-04-28 11:45:59 -04:00
|
|
|
DocManager = require "./DocManager"
|
|
|
|
logger = require "logger-sharelatex"
|
2015-06-02 15:29:32 -04:00
|
|
|
DocArchive = require "./DocArchiveManager"
|
2015-10-16 05:13:54 -04:00
|
|
|
HealthChecker = require "./HealthChecker"
|
|
|
|
|
2014-04-28 11:45:59 -04:00
|
|
|
|
|
|
|
module.exports = HttpController =
|
|
|
|
getDoc: (req, res, next = (error) ->) ->
|
|
|
|
project_id = req.params.project_id
|
2014-04-29 06:49:09 -04:00
|
|
|
doc_id = req.params.doc_id
|
2015-02-03 09:05:08 -05:00
|
|
|
include_deleted = req.query?.include_deleted == "true"
|
2014-04-28 11:45:59 -04:00
|
|
|
logger.log project_id: project_id, doc_id: doc_id, "getting doc"
|
2017-03-15 18:09:56 -04:00
|
|
|
DocManager.getFullDoc project_id, doc_id, (error, doc) ->
|
2014-04-28 11:45:59 -04:00
|
|
|
return next(error) if error?
|
2017-09-20 03:42:08 -04:00
|
|
|
logger.log {doc_id, project_id}, "got doc"
|
2014-04-28 11:45:59 -04:00
|
|
|
if !doc?
|
|
|
|
res.send 404
|
2015-02-03 09:05:08 -05:00
|
|
|
else if doc.deleted && !include_deleted
|
|
|
|
res.send 404
|
2014-04-28 11:45:59 -04:00
|
|
|
else
|
2014-04-30 08:06:12 -04:00
|
|
|
res.json HttpController._buildDocView(doc)
|
|
|
|
|
2014-05-20 08:04:33 -04:00
|
|
|
getRawDoc: (req, res, next = (error)->)->
|
|
|
|
project_id = req.params.project_id
|
|
|
|
doc_id = req.params.doc_id
|
|
|
|
logger.log project_id: project_id, doc_id: doc_id, "getting raw doc"
|
2017-03-15 18:09:56 -04:00
|
|
|
DocManager.getDocLines project_id, doc_id, (error, doc) ->
|
2014-05-20 08:04:33 -04:00
|
|
|
return next(error) if error?
|
|
|
|
if !doc?
|
|
|
|
res.send 404
|
|
|
|
else
|
|
|
|
res.setHeader('content-type', 'text/plain')
|
|
|
|
res.send HttpController._buildRawDocView(doc)
|
|
|
|
|
2014-04-30 08:06:12 -04:00
|
|
|
getAllDocs: (req, res, next = (error) ->) ->
|
|
|
|
project_id = req.params.project_id
|
|
|
|
logger.log project_id: project_id, "getting all docs"
|
2016-12-05 12:27:31 -05:00
|
|
|
DocManager.getAllNonDeletedDocs project_id, {lines: true, rev: true}, (error, docs = []) ->
|
2014-04-30 08:06:12 -04:00
|
|
|
return next(error) if error?
|
2016-12-09 09:37:24 -05:00
|
|
|
res.json HttpController._buildDocsArrayView(project_id, docs)
|
|
|
|
|
|
|
|
getAllRanges: (req, res, next = (error) ->) ->
|
|
|
|
project_id = req.params.project_id
|
|
|
|
logger.log {project_id}, "getting all ranges"
|
|
|
|
DocManager.getAllNonDeletedDocs project_id, {ranges: true}, (error, docs = []) ->
|
|
|
|
return next(error) if error?
|
|
|
|
res.json HttpController._buildDocsArrayView(project_id, docs)
|
2014-04-29 06:49:09 -04:00
|
|
|
|
|
|
|
updateDoc: (req, res, next = (error) ->) ->
|
|
|
|
project_id = req.params.project_id
|
|
|
|
doc_id = req.params.doc_id
|
|
|
|
lines = req.body?.lines
|
2016-11-28 09:55:16 -05:00
|
|
|
version = req.body?.version
|
2016-12-05 09:21:49 -05:00
|
|
|
ranges = req.body?.ranges
|
2014-04-29 06:49:09 -04:00
|
|
|
|
|
|
|
if !lines? or lines not instanceof Array
|
|
|
|
logger.error project_id: project_id, doc_id: doc_id, "no doc lines provided"
|
|
|
|
res.send 400 # Bad Request
|
|
|
|
return
|
2016-12-02 10:17:38 -05:00
|
|
|
|
|
|
|
if !version? or typeof version is not "number"
|
|
|
|
logger.error project_id: project_id, doc_id: doc_id, "no doc version provided"
|
|
|
|
res.send 400 # Bad Request
|
|
|
|
return
|
2017-01-19 06:15:14 -05:00
|
|
|
|
|
|
|
if !ranges?
|
|
|
|
logger.error project_id: project_id, doc_id: doc_id, "no doc ranges provided"
|
|
|
|
res.send 400 # Bad Request
|
|
|
|
return
|
2014-04-29 06:49:09 -04:00
|
|
|
|
2015-01-20 08:46:57 -05:00
|
|
|
logger.log project_id: project_id, doc_id: doc_id, "got http request to update doc"
|
2016-12-05 09:21:49 -05:00
|
|
|
DocManager.updateDoc project_id, doc_id, lines, version, ranges, (error, modified, rev) ->
|
2014-04-29 06:49:09 -04:00
|
|
|
return next(error) if error?
|
|
|
|
res.json {
|
|
|
|
modified: modified
|
2014-05-08 10:43:08 -04:00
|
|
|
rev: rev
|
2014-04-29 11:36:10 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
deleteDoc: (req, res, next = (error) ->) ->
|
|
|
|
project_id = req.params.project_id
|
|
|
|
doc_id = req.params.doc_id
|
|
|
|
logger.log project_id: project_id, doc_id: doc_id, "deleting doc"
|
|
|
|
DocManager.deleteDoc project_id, doc_id, (error) ->
|
|
|
|
return next(error) if error?
|
2014-04-30 08:06:12 -04:00
|
|
|
res.send 204
|
|
|
|
|
|
|
|
_buildDocView: (doc) ->
|
2016-12-09 09:37:24 -05:00
|
|
|
doc_view = { _id: doc._id?.toString() }
|
|
|
|
for attribute in ["lines", "rev", "version", "ranges", "deleted"]
|
|
|
|
if doc[attribute]?
|
|
|
|
doc_view[attribute] = doc[attribute]
|
2016-11-28 09:55:16 -05:00
|
|
|
return doc_view
|
2014-05-20 08:04:33 -04:00
|
|
|
|
|
|
|
_buildRawDocView: (doc)->
|
2014-05-29 06:18:31 -04:00
|
|
|
return (doc?.lines or []).join("\n")
|
2016-12-09 09:37:24 -05:00
|
|
|
|
|
|
|
_buildDocsArrayView: (project_id, docs) ->
|
|
|
|
docViews = []
|
|
|
|
for doc in docs
|
|
|
|
if doc? # There can end up being null docs for some reason :( (probably a race condition)
|
|
|
|
docViews.push HttpController._buildDocView(doc)
|
|
|
|
else
|
|
|
|
logger.error err: new Error("null doc"), project_id: project_id, "encountered null doc"
|
|
|
|
return docViews
|
2015-06-01 17:24:40 -04:00
|
|
|
|
|
|
|
archiveAllDocs: (req, res, next = (error) ->) ->
|
|
|
|
project_id = req.params.project_id
|
|
|
|
logger.log project_id: project_id, "archiving all docs"
|
2015-06-02 14:55:22 -04:00
|
|
|
DocArchive.archiveAllDocs project_id, (error) ->
|
2015-06-01 17:24:40 -04:00
|
|
|
return next(error) if error?
|
|
|
|
res.send 204
|
2015-08-13 17:48:45 -04:00
|
|
|
|
|
|
|
unArchiveAllDocs: (req, res, next = (error) ->) ->
|
|
|
|
project_id = req.params.project_id
|
|
|
|
logger.log project_id: project_id, "unarchiving all docs"
|
|
|
|
DocArchive.unArchiveAllDocs project_id, (error) ->
|
|
|
|
return next(error) if error?
|
|
|
|
res.send 200
|
|
|
|
|
2019-07-02 07:45:54 -04:00
|
|
|
destroyAllDocs: (req, res, next = (error) ->) ->
|
|
|
|
project_id = req.params.project_id
|
|
|
|
logger.log project_id: project_id, "destroying all docs"
|
|
|
|
DocArchive.destroyAllDocs project_id, (error) ->
|
|
|
|
return next(error) if error?
|
|
|
|
res.send 204
|
|
|
|
|
2015-10-16 05:13:54 -04:00
|
|
|
healthCheck: (req, res)->
|
|
|
|
HealthChecker.check (err)->
|
|
|
|
if err?
|
|
|
|
logger.err err:err, "error performing health check"
|
|
|
|
res.send 500
|
|
|
|
else
|
|
|
|
res.send 200
|
|
|
|
|