2014-05-07 14:29:04 +00:00
|
|
|
Path = require "path"
|
2014-02-12 10:23:40 +00:00
|
|
|
express = require('express')
|
|
|
|
Settings = require('settings-sharelatex')
|
|
|
|
logger = require 'logger-sharelatex'
|
|
|
|
metrics = require('./Metrics')
|
|
|
|
crawlerLogger = require('./CrawlerLogger')
|
|
|
|
expressLocals = require('./ExpressLocals')
|
|
|
|
socketIoConfig = require('./SocketIoConfig')
|
|
|
|
Router = require('../router')
|
|
|
|
metrics.inc("startup")
|
|
|
|
SessionSockets = require('session.socket.io')
|
2014-09-26 16:04:33 +00:00
|
|
|
|
|
|
|
|
|
|
|
redis = require("redis-sharelatex")
|
|
|
|
rclient = redis.createClient(Settings.redis.web)
|
|
|
|
|
|
|
|
RedisStore = require('connect-redis')(express)
|
|
|
|
sessionStore = new RedisStore(client:rclient)
|
|
|
|
|
2014-02-12 10:23:40 +00:00
|
|
|
cookieParser = express.cookieParser(Settings.security.sessionSecret)
|
|
|
|
oneDayInMilliseconds = 86400000
|
|
|
|
ReferalConnect = require('../Features/Referal/ReferalConnect')
|
2014-07-01 14:44:12 +00:00
|
|
|
RedirectManager = require("./RedirectManager")
|
2014-07-01 15:00:42 +00:00
|
|
|
OldAssetProxy = require("./OldAssetProxy")
|
2014-08-05 10:15:17 +00:00
|
|
|
translations = require("translations-sharelatex").setup(Settings.i18n)
|
2014-09-08 14:40:46 +00:00
|
|
|
Modules = require "./Modules"
|
2014-02-12 10:23:40 +00:00
|
|
|
|
2014-05-07 14:29:04 +00:00
|
|
|
metrics.mongodb.monitor(Path.resolve(__dirname + "/../../../node_modules/mongojs/node_modules/mongodb"), logger)
|
|
|
|
metrics.mongodb.monitor(Path.resolve(__dirname + "/../../../node_modules/mongoose/node_modules/mongodb"), logger)
|
2014-02-12 10:23:40 +00:00
|
|
|
|
|
|
|
Settings.editorIsOpen ||= true
|
|
|
|
|
|
|
|
if Settings.cacheStaticAssets
|
|
|
|
staticCacheAge = (oneDayInMilliseconds * 365)
|
|
|
|
else
|
|
|
|
staticCacheAge = 0
|
|
|
|
|
|
|
|
app = express()
|
|
|
|
|
2014-08-20 17:01:21 +00:00
|
|
|
cookieKey = Settings.cookieName
|
2014-02-12 10:23:40 +00:00
|
|
|
cookieSessionLength = 5 * oneDayInMilliseconds
|
|
|
|
|
|
|
|
csrf = express.csrf()
|
|
|
|
ignoreCsrfRoutes = []
|
|
|
|
app.ignoreCsrf = (method, route) ->
|
|
|
|
ignoreCsrfRoutes.push new express.Route(method, route)
|
|
|
|
|
2014-07-30 13:22:36 +00:00
|
|
|
|
2014-06-25 09:34:23 +00:00
|
|
|
app.configure () ->
|
|
|
|
if Settings.behindProxy
|
|
|
|
app.enable('trust proxy')
|
2014-02-12 10:23:40 +00:00
|
|
|
app.use express.static(__dirname + '/../../../public', {maxAge: staticCacheAge })
|
|
|
|
app.set 'views', __dirname + '/../../views'
|
|
|
|
app.set 'view engine', 'jade'
|
2014-09-08 14:40:46 +00:00
|
|
|
Modules.loadViewIncludes app
|
2014-05-15 15:32:17 +00:00
|
|
|
app.use express.bodyParser(uploadDir: Settings.path.uploadFolder)
|
2014-02-12 10:23:40 +00:00
|
|
|
app.use express.bodyParser(uploadDir: __dirname + "/../../../data/uploads")
|
2014-03-26 16:35:13 +00:00
|
|
|
app.use translations.expressMiddlewear
|
2014-08-04 15:47:14 +00:00
|
|
|
app.use translations.setLangBasedOnDomainMiddlewear
|
2014-02-12 10:23:40 +00:00
|
|
|
app.use cookieParser
|
|
|
|
app.use express.session
|
2014-06-25 09:34:23 +00:00
|
|
|
proxy: Settings.behindProxy
|
2014-02-12 10:23:40 +00:00
|
|
|
cookie:
|
2014-08-04 15:47:14 +00:00
|
|
|
domain: Settings.cookieDomain
|
2014-02-12 10:23:40 +00:00
|
|
|
maxAge: cookieSessionLength
|
|
|
|
secure: Settings.secureCookie
|
|
|
|
store: sessionStore
|
|
|
|
key: cookieKey
|
2014-09-10 09:09:25 +00:00
|
|
|
|
2014-02-12 10:23:40 +00:00
|
|
|
# Measure expiry from last request, not last login
|
|
|
|
app.use (req, res, next) ->
|
2014-09-04 17:07:31 +00:00
|
|
|
req.session.touch()
|
2014-02-12 10:23:40 +00:00
|
|
|
next()
|
|
|
|
|
|
|
|
app.use (req, res, next) ->
|
|
|
|
for route in ignoreCsrfRoutes
|
|
|
|
if route.method == req.method?.toLowerCase() and route.match(req.path)
|
|
|
|
return next()
|
|
|
|
csrf(req, res, next)
|
|
|
|
|
|
|
|
app.use ReferalConnect.use
|
|
|
|
app.use express.methodOverride()
|
2014-07-30 13:22:36 +00:00
|
|
|
|
2014-02-12 10:23:40 +00:00
|
|
|
expressLocals(app)
|
|
|
|
|
|
|
|
app.configure 'production', ->
|
|
|
|
logger.info "Production Enviroment"
|
|
|
|
app.enable('view cache')
|
|
|
|
|
2014-05-07 14:29:04 +00:00
|
|
|
app.use metrics.http.monitor(logger)
|
2014-07-01 14:44:12 +00:00
|
|
|
app.use RedirectManager
|
2014-07-01 15:00:42 +00:00
|
|
|
app.use OldAssetProxy
|
2014-02-12 10:23:40 +00:00
|
|
|
|
|
|
|
app.use (req, res, next)->
|
|
|
|
metrics.inc "http-request"
|
|
|
|
crawlerLogger.log(req)
|
|
|
|
next()
|
|
|
|
|
|
|
|
app.use (req, res, next) ->
|
|
|
|
if !Settings.editorIsOpen
|
|
|
|
res.status(503)
|
2014-08-01 12:47:14 +00:00
|
|
|
res.render("general/closed", {title:"maintenance"})
|
2014-02-12 10:23:40 +00:00
|
|
|
else
|
|
|
|
next()
|
|
|
|
|
|
|
|
app.get "/status", (req, res)->
|
|
|
|
res.send("web sharelatex is alive")
|
|
|
|
req.session.destroy()
|
|
|
|
|
|
|
|
logger.info ("creating HTTP server").yellow
|
|
|
|
server = require('http').createServer(app)
|
|
|
|
|
|
|
|
io = require('socket.io').listen(server)
|
|
|
|
|
|
|
|
sessionSockets = new SessionSockets(io, sessionStore, cookieParser, cookieKey)
|
|
|
|
router = new Router(app, io, sessionSockets)
|
|
|
|
socketIoConfig.configure(io)
|
|
|
|
|
|
|
|
module.exports =
|
|
|
|
io: io
|
|
|
|
app: app
|
|
|
|
server: server
|