overleaf/services/track-changes/app/coffee/HttpController.coffee

48 lines
1.4 KiB
CoffeeScript
Raw Normal View History

UpdatesManager = require "./UpdatesManager"
DiffManager = require "./DiffManager"
logger = require "logger-sharelatex"
module.exports = HttpController =
2014-02-26 06:34:56 -05:00
flushUpdatesWithLock: (req, res, next = (error) ->) ->
doc_id = req.params.doc_id
2014-02-26 06:34:56 -05:00
logger.log doc_id: doc_id, "compressing doc history"
UpdatesManager.processUncompressedUpdatesWithLock doc_id, (error) ->
return next(error) if error?
res.send 204
getDiff: (req, res, next = (error) ->) ->
doc_id = req.params.doc_id
project_id = req.params.project_id
if req.query.from?
from = parseInt(req.query.from, 10)
else
from = null
if req.query.to?
to = parseInt(req.query.to, 10)
else
to = null
logger.log project_id, doc_id: doc_id, from: from, to: to, "getting diff"
DiffManager.getDiff project_id, doc_id, from, to, (error, diff) ->
return next(error) if error?
res.send JSON.stringify(diff: diff)
getUpdates: (req, res, next = (error) ->) ->
doc_id = req.params.doc_id
project_id = req.params.project_id
if req.query.to?
to = parseInt(req.query.to, 10)
if req.query.limit?
limit = parseInt(req.query.limit, 10)
UpdatesManager.getUpdatesWithUserInfo doc_id, to: to, limit: limit, (error, updates) ->
return next(error) if error?
formattedUpdates = for update in updates
{
meta: update.meta
2014-03-06 06:00:49 -05:00
v: update.v
}
res.send JSON.stringify updates: formattedUpdates