2016-11-09 12:06:32 +00:00
|
|
|
logger = require "logger-sharelatex"
|
|
|
|
logger.initialize("real-time-sharelatex")
|
|
|
|
|
2014-11-07 17:38:12 +00:00
|
|
|
express = require("express")
|
|
|
|
session = require("express-session")
|
|
|
|
redis = require("redis-sharelatex")
|
2016-11-09 12:06:32 +00:00
|
|
|
ioredis = require('ioredis')
|
|
|
|
Settings = require "settings-sharelatex"
|
|
|
|
|
|
|
|
redisSessionsSettings = Settings.redis.websessions or Settings.redis.web
|
|
|
|
|
|
|
|
if redisSessionsSettings?.cluster?
|
|
|
|
logger.log {}, "using redis cluster for web sessions"
|
2016-11-09 12:09:15 +00:00
|
|
|
sessionRedisClient = new ioredis.Cluster(redisSessionsSettings.cluster)
|
2016-11-09 12:06:32 +00:00
|
|
|
else
|
2016-11-09 12:09:15 +00:00
|
|
|
sessionRedisClient = redis.createClient(redisSessionsSettings)
|
2016-11-09 12:06:32 +00:00
|
|
|
|
2014-11-07 17:38:12 +00:00
|
|
|
RedisStore = require('connect-redis')(session)
|
|
|
|
SessionSockets = require('session.socket.io')
|
|
|
|
CookieParser = require("cookie-parser")
|
|
|
|
|
|
|
|
Metrics = require("metrics-sharelatex")
|
2015-12-07 11:49:55 +00:00
|
|
|
Metrics.initialize(Settings.appName or "real-time")
|
2015-12-03 16:50:56 +00:00
|
|
|
Metrics.event_loop.monitor(logger)
|
2014-11-07 17:38:12 +00:00
|
|
|
|
|
|
|
|
|
|
|
# Set up socket.io server
|
|
|
|
app = express()
|
|
|
|
server = require('http').createServer(app)
|
|
|
|
io = require('socket.io').listen(server)
|
|
|
|
|
|
|
|
# Bind to sessions
|
2016-11-09 12:09:15 +00:00
|
|
|
sessionStore = new RedisStore(client: sessionRedisClient)
|
2014-11-07 17:38:12 +00:00
|
|
|
cookieParser = CookieParser(Settings.security.sessionSecret)
|
|
|
|
sessionSockets = new SessionSockets(io, sessionStore, cookieParser, Settings.cookieName)
|
|
|
|
|
|
|
|
io.configure ->
|
|
|
|
io.enable('browser client minification')
|
|
|
|
io.enable('browser client etag')
|
|
|
|
|
|
|
|
# Fix for Safari 5 error of "Error during WebSocket handshake: location mismatch"
|
|
|
|
# See http://answers.dotcloud.com/question/578/problem-with-websocket-over-ssl-in-safari-with
|
|
|
|
io.set('match origin protocol', true)
|
|
|
|
|
|
|
|
# gzip uses a Node 0.8.x method of calling the gzip program which
|
|
|
|
# doesn't work with 0.6.x
|
|
|
|
#io.enable('browser client gzip')
|
|
|
|
io.set('transports', ['websocket', 'flashsocket', 'htmlfile', 'xhr-polling', 'jsonp-polling'])
|
|
|
|
io.set('log level', 1)
|
2014-11-20 16:56:09 +00:00
|
|
|
|
|
|
|
app.get "/status", (req, res, next) ->
|
|
|
|
res.send "real-time-sharelatex is alive"
|
2016-11-09 12:06:32 +00:00
|
|
|
|
2014-11-20 16:56:09 +00:00
|
|
|
redisCheck = redis.activeHealthCheckRedis(Settings.redis.web)
|
|
|
|
app.get "/health_check/redis", (req, res, next) ->
|
|
|
|
if redisCheck.isAlive()
|
|
|
|
res.send 200
|
|
|
|
else
|
|
|
|
res.send 500
|
2016-11-09 12:06:32 +00:00
|
|
|
|
2014-11-07 17:38:12 +00:00
|
|
|
Router = require "./app/js/Router"
|
|
|
|
Router.configure(app, io, sessionSockets)
|
2014-11-13 16:03:37 +00:00
|
|
|
|
|
|
|
WebsocketLoadBalancer = require "./app/js/WebsocketLoadBalancer"
|
|
|
|
WebsocketLoadBalancer.listenForEditorEvents(io)
|
2014-11-14 15:30:18 +00:00
|
|
|
|
|
|
|
DocumentUpdaterController = require "./app/js/DocumentUpdaterController"
|
|
|
|
DocumentUpdaterController.listenForUpdatesFromDocumentUpdater(io)
|
2016-11-09 12:06:32 +00:00
|
|
|
|
2014-11-07 17:38:12 +00:00
|
|
|
port = Settings.internal.realTime.port
|
|
|
|
host = Settings.internal.realTime.host
|
|
|
|
|
|
|
|
server.listen port, host, (error) ->
|
|
|
|
throw error if error?
|
2015-04-30 14:05:31 +00:00
|
|
|
logger.info "realtime starting up, listening on #{host}:#{port}"
|
2016-11-09 12:06:32 +00:00
|
|
|
|
2014-11-25 09:17:26 +00:00
|
|
|
# Stop huge stack traces in logs from all the socket.io parsing steps.
|
2016-11-09 12:06:32 +00:00
|
|
|
Error.stackTraceLimit = 10
|