mirror of
https://github.com/overleaf/overleaf.git
synced 2024-10-31 21:21:03 -04:00
69 lines
2.5 KiB
CoffeeScript
69 lines
2.5 KiB
CoffeeScript
|
express = require('express')
|
||
|
http = require("http")
|
||
|
Settings = require('settings-sharelatex')
|
||
|
logger = require('logger-sharelatex')
|
||
|
logger.initialize("documentupdater")
|
||
|
RedisManager = require('./app/js/RedisManager.js')
|
||
|
UpdateManager = require('./app/js/UpdateManager.js')
|
||
|
Keys = require('./app/js/RedisKeyBuilder')
|
||
|
redis = require('redis')
|
||
|
rclient = redis.createClient(Settings.redis.port, Settings.redis.host)
|
||
|
rclient.auth(Settings.redis.password)
|
||
|
metrics = require('./app/js/Metrics')
|
||
|
Errors = require "./app/js/Errors"
|
||
|
HttpController = require "./app/js/HttpController"
|
||
|
|
||
|
app = express()
|
||
|
app.configure ->
|
||
|
app.use(express.logger(':remote-addr - [:date] - :user-agent ":method :url" :status - :response-time ms'));
|
||
|
app.use express.bodyParser()
|
||
|
app.use app.router
|
||
|
|
||
|
app.configure 'development', ()->
|
||
|
console.log "Development Enviroment"
|
||
|
app.use express.errorHandler({ dumpExceptions: true, showStack: true })
|
||
|
|
||
|
app.configure 'production', ()->
|
||
|
console.log "Production Enviroment"
|
||
|
app.use express.logger()
|
||
|
app.use express.errorHandler()
|
||
|
|
||
|
rclient.subscribe("pending-updates")
|
||
|
rclient.on "message", (channel, doc_key)->
|
||
|
[project_id, doc_id] = Keys.splitProjectIdAndDocId(doc_key)
|
||
|
UpdateManager.processOutstandingUpdatesWithLock project_id, doc_id, (error) ->
|
||
|
logger.error err: error, project_id: project_id, doc_id: doc_id, "error processing update" if error?
|
||
|
|
||
|
UpdateManager.resumeProcessing()
|
||
|
|
||
|
app.use (req, res, next)->
|
||
|
metrics.inc "http-request"
|
||
|
next()
|
||
|
|
||
|
app.get '/project/:project_id/doc/:doc_id', HttpController.getDoc
|
||
|
app.post '/project/:project_id/doc/:doc_id', HttpController.setDoc
|
||
|
app.post '/project/:project_id/doc/:doc_id/flush', HttpController.flushDocIfLoaded
|
||
|
app.delete '/project/:project_id/doc/:doc_id', HttpController.flushAndDeleteDoc
|
||
|
app.delete '/project/:project_id', HttpController.deleteProject
|
||
|
app.post '/project/:project_id/flush', HttpController.flushProject
|
||
|
|
||
|
app.get '/total', (req, res)->
|
||
|
timer = new metrics.Timer("http.allDocList")
|
||
|
RedisManager.getCountOfDocsInMemory (err, count)->
|
||
|
timer.done()
|
||
|
res.send {total:count}
|
||
|
|
||
|
app.get '/status', (req, res)->
|
||
|
res.send('document updater is alive')
|
||
|
|
||
|
app.use (error, req, res, next) ->
|
||
|
logger.error err: error, "request errored"
|
||
|
if error instanceof Errors.NotFoundError
|
||
|
res.send 404
|
||
|
else
|
||
|
res.send(500, "Oops, something went wrong")
|
||
|
|
||
|
port = Settings.internal?.documentupdater?.port or Settings.apis?.documentupdater?.port or 3003
|
||
|
app.listen port, "localhost", ->
|
||
|
logger.log("documentupdater-sharelatex server listening on port #{port}")
|