Source: app.js

/**
 * app module
 *
 * The University of Scouting application allows users to view their transcript data.  See README.md for more details.
 *
 * @module app
 */

// pull in environment variables from .env
// DATABASE_URL - mongodb connection string
require("dotenv").config();

// require modules
var mongoose = require("mongoose");
var createError = require("http-errors");
var express = require("express");
var path = require("path");
var cookieParser = require("cookie-parser");
var passport = require("passport");
var LocalStrategy = require("passport-local").Strategy;
var ensureLogin = require("connect-ensure-login");
var csv = require("express-csv");
var bodyParser = require('body-parser');

// initialize app
var app = express();

// database setup
mongoose.connect(process.env.DATABASE_URL, { useNewUrlParser: true });
var db = mongoose.connection;
db.on("error", function (error) {
  console.error(error);
});
db.once("open", function () {
  console.log("connected to database");
});

// view engine setup
app.set("views", path.join(__dirname, "views"));
app.set("view engine", "ejs");



// logging middleware
app.use(require("morgan")("dev"));

// static files middleware
app.use(express.static(path.join(__dirname, "public")));

// encoding and session middleware
app.use(express.json());
app.use(express.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(require("express-session")({ secret: process.env.SESSION_SECRET }));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: true }));

// passport authentication session setup
passport.serializeUser(require("./lib/serializeuser"));
passport.deserializeUser(require("./lib/deserializeuser"));
passport.use(new LocalStrategy(require('./lib/localauthentication')));
app.use(passport.initialize());
app.use(passport.session());

// flass message middleware
app.use(require("connect-flash")());

// routes registered as middleware
// each module provides sub-routes beneath the path specified
app.use("/", require("./routes/index"));
app.use("/login", require("./routes/login"));
app.use("/logout", require("./routes/logout"));
app.use("/profile", ensureLogin.ensureLoggedIn(), require("./routes/profile"));
app.use("/schedule", ensureLogin.ensureLoggedIn(), require("./routes/schedule"));
app.use("/transcript", ensureLogin.ensureLoggedIn(), require("./routes/transcript"));
app.use("/searchMembers", ensureLogin.ensureLoggedIn(), require("./routes/searchMembers"));
app.use("/api", ensureLogin.ensureLoggedIn(), require("./routes/api"));
// Secondary pages
app.use("/howtoprinttopdf", ensureLogin.ensureLoggedIn(), require("./routes/howtoprinttopdf"));
app.use("/transcriptPrint", ensureLogin.ensureLoggedIn(), require("./routes/transcriptPrint"));
app.use("/popupSchedule", ensureLogin.ensureLoggedIn(), require("./routes/popupSchedule"));
app.use("/popupTranscript", ensureLogin.ensureLoggedIn(), require("./routes/popupTranscript"));
app.use("/schedulePrint", ensureLogin.ensureLoggedIn(), require("./routes/schedulePrint"));

/**
 * catch and generate 404 errors.
 *
 * Catch any yet unhandled routes and generate a 404 error to be handled by the errorHandler function.
 *
 * @private
 * @memberof module:app
 * @param {Object}   req                request object
 * @param {Object}   res                response object
 * @param {Function} next               function call to next middleware
 */
function notFoundHandler(req, res, next) {
  next(createError(404));
}
app.use(notFoundHandler);

/**
 * handle final errors.
 *
 * Display errors using the "error" view.
 *
 * @private
 * @memberof module:app
 * @param {Object}   err                error object
 * @param {Object}   req                request object
 * @param {Object}   res                response object
 * @param {Function} next               function call to next middleware
 */
function errorHandler(err, req, res, next) {
  // 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");
}
app.use(errorHandler);

module.exports = app;