overleaf/services/docstore/app/coffee/HttpController.coffee

107 lines
3.3 KiB
CoffeeScript
Raw Normal View History

DocManager = require "./DocManager"
logger = require "logger-sharelatex"
2015-06-02 15:29:32 -04:00
DocArchive = require "./DocArchiveManager"
HealthChecker = require "./HealthChecker"
module.exports = HttpController =
getDoc: (req, res, next = (error) ->) ->
project_id = req.params.project_id
doc_id = req.params.doc_id
include_deleted = req.query?.include_deleted == "true"
logger.log project_id: project_id, doc_id: doc_id, "getting doc"
DocManager.getDoc project_id, doc_id, (error, doc) ->
return next(error) if error?
2014-06-05 08:29:50 -04:00
logger.log doc: doc, "got doc"
if !doc?
res.send 404
else if doc.deleted && !include_deleted
res.send 404
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"
DocManager.getDoc project_id, doc_id, (error, doc) ->
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"
DocManager.getAllDocs project_id, (error, docs = []) ->
return next(error) if error?
2014-05-07 11:24:47 -04:00
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"
2014-05-07 11:24:47 -04:00
res.json docViews
updateDoc: (req, res, next = (error) ->) ->
project_id = req.params.project_id
doc_id = req.params.doc_id
lines = req.body?.lines
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
logger.log project_id: project_id, doc_id: doc_id, "got http request to update doc"
2014-05-16 08:06:35 -04:00
DocManager.updateDoc project_id, doc_id, lines, (error, modified, rev) ->
return next(error) if error?
res.json {
modified: modified
rev: rev
}
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) ->
return {
2014-05-29 07:04:18 -04:00
_id: doc._id?.toString()
2014-04-30 08:06:12 -04:00
lines: doc.lines
rev: doc.rev
2014-06-05 08:29:50 -04:00
deleted: !!doc.deleted
2014-05-20 08:04:33 -04:00
}
_buildRawDocView: (doc)->
2014-05-29 06:18:31 -04:00
return (doc?.lines or []).join("\n")
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
healthCheck: (req, res)->
HealthChecker.check (err)->
if err?
logger.err err:err, "error performing health check"
res.send 500
else
res.send 200