-
Notifications
You must be signed in to change notification settings - Fork 3
Expand file tree
/
Copy pathserver.js
More file actions
100 lines (88 loc) · 2.21 KB
/
Copy pathserver.js
File metadata and controls
100 lines (88 loc) · 2.21 KB
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
89
90
91
92
93
94
95
96
97
98
99
100
/**
* Webapp
*/
var express = require("express"),
bodyParser = require("body-parser"),
session = require("express-session"),
csrf = require("csurf"),
MongoStore = require("connect-mongo")(session),
hogan = require("hogan-express"),
passport = require("passport"),
path = require("path"),
routes = require("./routes"),
config = require("config");
var app = express();
// express settings
app.disable("x-powered-by");
app.set("port", process.env.PORT || config.server.port || 3000);
// view settings
app.set("views", path.resolve(__dirname, "views"));
app.set("view engine", "html");
app.engine("html", hogan);
// middleware
app.use(express.static(path.resolve(__dirname, "public")));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded());
app.use(session({
name: config.session.name,
cookie: config.session.cookie,
secret: config.session.secret,
store: new MongoStore({
db: config.db.name,
host: config.db.host,
port: config.db.port,
username: config.db.user,
password: config.db.pass
})
}));
/* comment out (後々使います)
app.use(csrf());
app.use(function (req, res, next) {
res.locals._csrf = req.csrfToken();
next();
});
//*/
// passport settings
app.use(passport.initialize());
app.use(passport.session());
app.use(function (req, res, next) {
res.locals.user = req.user;
next();
});
// load routes
app.use(routes);
// development error handler
// will print stacktrace
if (app.get("env") === "development") {
app.use(function(err, req, res, next) {
console.error(err);
res.status(err.status || 500);
res.render("error", {
message: err.message,
error: err
});
});
} else {
process.on("uncaughtException", function (err) {
console.error(err);
});
}
// production error handler
// no stacktraces leaked to user
app.use(function(err, req, res, next) {
console.error(err);
res.status(err.status || 500);
res.render("error", {
message: err.message,
error: null
});
});
if (module.parent) {
// for API test
module.exports = app;
} else {
// start server
var server = app.listen(app.get("port"), function() {
console.log("Express server listening on " + JSON.stringify(server.address()));
});
}