-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathapp.js
62 lines (53 loc) · 2.46 KB
/
app.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
// code adapted from http://mherman.org/blog/2016/03/13/designing-a-restful-api-with-node-and-postgres/#.WLNT_vkrJPb
var express = require('express'); // imports framework into app
var path = require('path'); // path is a Node module for working with and handling paths
var logger = require('morgan'); // Express middleware for logging requests and responses
var bodyParser = require('body-parser'); // adds a body object to your request so that you can access POST parameters
var favicon = require('serve-favicon');
//var cookieParser = require('cookie-parser');
// paths to routers
var directory = require('./routes/directory');
var contribute = require('./routes/contribute');
var contact = require('./routes/contact');
var glossary = require('./routes/glossary');
var about = require('./routes/about');
var categories = require('./routes/browse-categories');
var get = require('./routes/get-data');
var api = require('./routes/api');
var app = express(); // initate app
app.use(express.static(path.join(__dirname, 'public'))); // tells app to use the /public directory
// view engine setup
app.set('views', path.join(__dirname, 'views')); // path.join() normalises all the arguments into a path string. _dirname = global and 'views' = file/folder name
//app.engine('html', require('ejs').renderFile);
app.set('view engine', 'jade'); // set the view engine to html
app.set('view options', {
layout: false
});
app.use(logger('dev')); // logs the requests to the console
app.use(bodyParser.json()); // gives app the ability to parse JSON
app.use(bodyParser.urlencoded({ extended: false })); // allows app to read data from URLs
app.use(favicon(path.join(__dirname, 'public', 'favicon.ico')));
// app.use(cookieParser()); // adds cookie object to all requests you get
// create routes from the above paths to the following html pages
app.use('/', directory);
app.use('/contribute', contribute);
app.use('/contact', contact);
app.use('/glossary', glossary);
app.use('/about', about);
app.use('/categories', categories);
app.use('/', get);
app.use('/api', api);
// catch 404 and forward to error handler. 404 error indicates the app ran out of options
app.use(function(req, res, next) {
var err = new Error('Not Found');
err.status = 404;
next(err);
});
//error handler
app.use(function(err, req, res, next) {
res.locals.message = err.message;
res.locals.error = req.app.get('env') === 'development' ? err : {};
res.render('error.jade');
res.status(err.status || 500);
});
module.exports = app;