This repository has been archived by the owner on Aug 24, 2019. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathapp.js
88 lines (72 loc) · 2.06 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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
"use strict";
var express = require( "express" );
var path = require( "path" );
var favicon = require( "serve-favicon" );
var logger = require( "morgan" );
var cookieParser = require( "cookie-parser" );
var bodyParser = require( "body-parser" );
var multer = require( "multer" );
var session = require( "express-session" );
var flash = require( "connect-flash" );
var cvrView = require( "cvr-view" );
var app = express();
// proxy setup
app.set( "trust proxy", true );
// view engine setup
app.set( "views", cvrView.viewsPath );
app.set( "view engine", "html" );
app.engine( "html", cvrView.hbs.__express );
// uncomment after placing your favicon in /public
//app.use(favicon(__dirname + "/public/favicon.ico" ));
app.use( logger( "dev" ));
app.use( bodyParser.json({ limit: "5mb" }));
app.use( bodyParser.urlencoded({ extended: false, limit: "5mb" }));
app.use( multer({ inMemory: true }));
app.use( cookieParser());
app.use( require( "less-middleware" )( cvrView.publicPath ) );
app.use( express.static( cvrView.publicPath ) );
// session
app.use( session({
secret: "adflkjaguadfnaadfjdfkKDJDFLSHsjkfh49584309dfjdfd"
}));
app.use( cvrView.passport.initialize() );
app.use( cvrView.passport.session() );
app.use( flash() );
// routing
app.use( "/", cvrView.routes );
// catch 404 and forward to error handler
app.use( function ( req, res, next )
{
var err = new Error( "Not Found" );
err.status = 404;
next( err );
});
// error handlers
// development error handler
// will print stacktrace
if ( app.get( "env" ) === "development" )
{
app.use( function ( err, req, res, next )
{
res.status( err.status || 500 );
res.render( "error", {
message: err.message,
error: err,
layout: "layout.html",
authed: req.isAuthenticated()
});
});
}
// production error handler
// no stacktraces leaked to user
app.use( function ( err, req, res, next )
{
res.status( err.status || 500 );
res.render( "error", {
message: err.message,
error: {},
layout: "layout.html",
authed: req.isAuthenticated()
});
});
module.exports = app;