-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.js
55 lines (43 loc) · 1.28 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
// Main Server
// /app.js
//
// Created by Walt Zimmerman on 8/24/16.
//
"use strict";
// Deeps
const express = require("express");
const path = require('path');
const cookieParser = require('cookie-parser');
const bodyParser = require('body-parser');
const app = express();
const fs = require("fs");
// PORT
const PORT = (process.env.PORT || 4003);
// Global usage of production env
global.isProduction = (process.env.NODE_ENV === "production");
// App root path
global.appRoot = path.resolve(__dirname);
//add timestamps in front of log messages
if(isProduction) require('console-stamp')(console, { pattern : "dd/mm/yyyy HH:MM:ss.l" });
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: true }));
// Router
app.use('/', require('./routes/index'));
// catch 404 and forward to error handler
app.use((req, res, next) => {
let err = new Error('Not Found');
err.status = 404;
next(err);
});
// production error handler
// no stacktraces leaked to user
app.use((err, req, res, next) => {
res.status(err.status || 500);
res.json({ error: err.message });
});
app.listen(PORT, (req, res, next) => {
console.log(`Running on port ${PORT}`);
console.log(`ENVIRONMENT: ${(global.isProduction) ? "PRODUCTION" : "DEVELOPMENT"}`);
});
// Export for testing
module.exports = app;