Skip to content

Instantly share code, notes, and snippets.

@varunon9
Created May 26, 2018 17:31
Show Gist options
  • Save varunon9/3848464fe952791986d766fd83b7deae to your computer and use it in GitHub Desktop.
Save varunon9/3848464fe952791986d766fd83b7deae to your computer and use it in GitHub Desktop.
app.js file for node.js server using express.
/**
* Created by: Varun kumar
* Date: 23 May, 2018
*/
const express = require('express');
const path = require('path');
//const favicon = require('serve-favicon');
const bodyParser = require('body-parser');
const cookieParser = require('cookie-parser');
const { graphqlExpress, graphiqlExpress } = require('apollo-server-express');
const env = process.env.NODE_ENV || 'development';
const config = require('./config/config.json')[env];
const middlewares = require('./middlewares');
/**
* Get all routes here
*/
const indexRoutes = require('./routes/index');
const dashboardRoutes = require('./routes/dashboard');
const app = express();
// setting view engine as ejs with file extension .html
app.set('views', __dirname + '/views');
app.engine('html', require('ejs').renderFile);
app.set('view engine', 'html');
/*app.use(favicon(path.join(__dirname, 'public/images', 'favicon.ico')));*/
app.use(bodyParser.json({
limit: '8mb'
})); // support json encoded bodies
app.use(bodyParser.urlencoded({
limit: '8mb',
extended: true
})); // support encoded bodies
app.use(cookieParser());
// to serve static and public files
app.use('/', express.static(path.join(__dirname, 'public')));
// logging POST Requests and parameters
app.use(function(req, res, next) {
if (req.method == 'POST') {
console.log('\x1b[36m%s\x1b[0m', 'Request URL:', req.originalUrl);
console.log(req.body);
console.log('\x1b[33m%s\x1b[0m', '---------------------------------');
}
next();
});
const schema = require('./graphql-schema');
/**
* Set all routes here, orders are important
*/
app.use('/', indexRoutes);
app.use('/dashboard', dashboardRoutes);
// The GraphQL endpoint, using security middleware: verifyToken
app.use('/graphql', middlewares.verifyToken, graphqlExpress((req) => ({
schema: schema,
context: {
user: req.decoded
}
})));
// GraphiQL, a visual editor for queries
//app.use('/graphiql', graphiqlExpress({ endpointURL: '/graphql' }));
// catch 404 and forward to error handler
app.use(function(req, res, next) {
const err = new Error('Not Found');
err.status = 404;
next(err);
});
// error handler
app.use(function(err, req, res, next) {
console.error(err);
// set locals, only providing error in development
res.locals.message = err.message;
res.locals.error = req.app.get('env') === 'development' ? err : {};
// render the error page
res.status(err.status || 500);
res.render('error');
});
module.exports = app;
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment