mirror of
https://github.com/codeninjasllc/codecombat.git
synced 2024-11-27 09:35:39 -05:00
131 lines
3.8 KiB
CoffeeScript
131 lines
3.8 KiB
CoffeeScript
# Put lodash and underscore.string into the global namespace
|
|
GLOBAL._ = require 'lodash'
|
|
_.str = require 'underscore.string'
|
|
_.mixin _.str.exports()
|
|
|
|
express = require 'express'
|
|
path = require 'path'
|
|
winston = require 'winston'
|
|
passport = require 'passport'
|
|
useragent = require 'express-useragent'
|
|
|
|
auth = require './server/auth'
|
|
db = require './server/db'
|
|
file = require './server/file'
|
|
folder = require './server/folder'
|
|
user = require './server/handlers/user'
|
|
logging = require './server/logging'
|
|
sprites = require './server/sprites'
|
|
contact = require './server/contact'
|
|
languages = require './server/languages'
|
|
multiplayer = require './server/multiplayer'
|
|
sendwithus = require './server/sendwithus'
|
|
|
|
https = require 'https'
|
|
http = require 'http'
|
|
fs = require 'graceful-fs'
|
|
|
|
config = require './server_config'
|
|
|
|
logging.setup()
|
|
db.connectDatabase()
|
|
|
|
# MailChimp setup
|
|
mcapi = require 'mailchimp-api'
|
|
mc = new mcapi.Mailchimp(config.mail.mailchimpAPIKey)
|
|
GLOBAL.mc = mc
|
|
|
|
# Express server setup
|
|
app = express()
|
|
|
|
active_responses = []
|
|
|
|
oldBrowser = (req, res, next) ->
|
|
return next() if req.query['try-old-browser-anyway'] or not isOldBrowser(req)
|
|
res.sendfile(path.join(__dirname, 'public', 'index_old_browser.html'))
|
|
|
|
# determines order of middleware and request handling
|
|
app.configure(->
|
|
app.use (req, res, next) ->
|
|
req.setTimeout 15000, ->
|
|
console.log 'timed out!'
|
|
req.abort()
|
|
self.emit('pass',message)
|
|
next()
|
|
|
|
app.use(express.logger('dev'))
|
|
app.use(express.static(path.join(__dirname, 'public')))
|
|
app.use(useragent.express())
|
|
app.use '/play/', oldBrowser # When they go directly to play a level, they won't see our browser warning, so give it to 'em.
|
|
app.set('port', config.port)
|
|
app.set('views', __dirname + '/app/views')
|
|
app.set('view engine', 'jade')
|
|
app.set('view options', { layout: false })
|
|
app.use(express.favicon())
|
|
app.use(express.cookieParser(config.cookie_secret))
|
|
app.use(express.bodyParser())
|
|
app.use(express.methodOverride())
|
|
app.use(express.cookieSession({secret:'defenestrate'}))
|
|
app.use(passport.initialize())
|
|
app.use(passport.session())
|
|
if(config.slow_down)
|
|
app.use((req, res, next) -> setTimeout((-> next()), 1000))
|
|
user.setupMiddleware(app)
|
|
|
|
app.use(app.router)
|
|
)
|
|
|
|
app.configure('development', -> app.use(express.errorHandler()))
|
|
|
|
multiplayer.connectToScoringQueue()
|
|
sendwithus.setupQueue()
|
|
|
|
|
|
auth.setupRoutes(app)
|
|
db.setupRoutes(app)
|
|
sprites.setupRoutes(app)
|
|
contact.setupRoutes(app)
|
|
file.setupRoutes(app)
|
|
folder.setupRoutes(app)
|
|
languages.setupRoutes(app)
|
|
multiplayer.setupRoutes(app)
|
|
sendwithus.setupQueue app
|
|
|
|
# Some sort of cross-domain communication hack facebook requires
|
|
app.get('/channel.html', (req, res) ->
|
|
res.sendfile(path.join(__dirname, 'public', 'channel.html'))
|
|
)
|
|
|
|
# blitz.io (load tester) auth
|
|
app.get '/mu-a2a0832f-10763ae9-170d6c87-70a62423', (req, res) ->
|
|
res.send('42')
|
|
|
|
# Anything that isn't handled at this point gets index.html
|
|
app.get('*', (req, res) ->
|
|
res.sendfile(path.join(__dirname, 'public', 'index.html'))
|
|
)
|
|
|
|
#ssl_options =
|
|
# key: fs.readFileSync('ssl/key.pem')
|
|
# cert: fs.readFileSync('ssl/cert.pem')
|
|
|
|
module.exports.startServer = ->
|
|
http.createServer(app).listen(app.get('port'))
|
|
winston.info("Express SSL server listening on port " + app.get('port'))
|
|
# https.createServer(ssl_options, app).listen(config['ssl_port']);
|
|
return app
|
|
|
|
isOldBrowser = (req) ->
|
|
# https://github.com/biggora/express-useragent/blob/master/lib/express-useragent.js
|
|
return false unless ua = req.useragent
|
|
return true if ua.isiPad or ua.isiPod or ua.isiPhone or ua.isOpera
|
|
return false unless ua and ua.Browser in ["Chrome", "Safari", "Firefox", "IE"] and ua.Version
|
|
b = ua.Browser
|
|
v = parseInt ua.Version.split('.')[0], 10
|
|
return true if b is 'Chrome' and v < 17
|
|
return true if b is 'Safari' and v < 6
|
|
return true if b is 'Firefox' and v < 21
|
|
return true if b is 'IE' and v < 10
|
|
false
|
|
|
|
|