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}")