// load dependencies const express = require('express'); const bodyParser = require('body-parser'); const siofu = require('socketio-file-upload'); const expressHandlebars = require('express-handlebars'); const Handlebars = require('handlebars'); const config = require('config'); const winston = require('winston'); const hostedContentPath = config.get('Database.PublishUploadPath'); // configure logging const logLevel = config.get('Logging.LogLevel'); const logDir = config.get('Logging.LogDirectory'); require('./config/loggerSetup.js')(winston, logLevel, logDir); // set port const PORT = 3000; // create an Express application const app = express(); // require our models for syncing const db = require('./models'); // serve static files from public directory (css/js/img) app.use(express.static(`${__dirname}/public`)); // configure express app app.enable('trust proxy'); // trust the proxy to get ip address for us app.use(bodyParser.json()); // for parsing application/json app.use(bodyParser.urlencoded({ extended: true })); // for parsing application/x-www-form-urlencoded app.use(siofu.router); app.use((req, res, next) => { // logging middleware winston.verbose(`Request on ${req.originalUrl} from ${req.ip}`); next(); }); // configure handlebars & register it with Express app const hbs = expressHandlebars.create({ defaultLayout: 'main', // sets the default layout handlebars : Handlebars, // includes basic handlebars for access to that library helpers : { // define any extra helpers you may need googleAnalytics () { const googleApiKey = config.get('AnalyticsConfig.GoogleId'); return new Handlebars.SafeString( `` ); }, ifConditional (varOne, operator, varTwo, options) { switch (operator) { case '===': return (varOne === varTwo) ? options.fn(this) : options.inverse(this); case '!==': return (varOne !== varTwo) ? options.fn(this) : options.inverse(this); case '<': return (varOne < varTwo) ? options.fn(this) : options.inverse(this); case '<=': return (varOne <= varTwo) ? options.fn(this) : options.inverse(this); case '>': return (varOne > varTwo) ? options.fn(this) : options.inverse(this); case '>=': return (varOne >= varTwo) ? options.fn(this) : options.inverse(this); case '&&': return (varOne && varTwo) ? options.fn(this) : options.inverse(this); case '||': return (varOne || varTwo) ? options.fn(this) : options.inverse(this); default: return options.inverse(this); } }, }, }); app.engine('handlebars', hbs.engine); app.set('view engine', 'handlebars'); // require express routes require('./routes/api-routes.js')(app); require('./routes/show-routes.js')(app); require('./routes/serve-routes.js')(app); require('./routes/home-routes.js')(app); // require socket.io routes const server = require('./routes/sockets-routes.js')(app, siofu, hostedContentPath); // sync sequelize // wrap the server in socket.io to intercept incoming sockets requests // start server db.sequelize.sync().then(() => { server.listen(PORT, () => { winston.info('Trusting proxy?', app.get('trust proxy')); winston.info(`Server is listening on PORT ${PORT}`); }); });