-
Notifications
You must be signed in to change notification settings - Fork 1
/
app.js
127 lines (116 loc) · 3.29 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
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
var express = require("express");
var path = require("path");
var cookieParser = require("cookie-parser");
const session = require("express-session");
var passport = require("passport");
var bodyParser = require("body-parser");
var LocalStrategy = require("passport-local").Strategy;
var fs = require("fs");
var config = require("./config/keys");
var app = express();
var morgan = require("morgan");
var jwt = require("jsonwebtoken");
// view engine setup
app.set("views", path.join(__dirname, "views"));
app.set("view engine", "ejs");
// app.use(logger("dev"));
app.use(express.json());
app.use(express.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, "public")));
/// passport setup
app.use(
session({ secret: config.passportKey, cookie: { maxAge: 1000 * 60 * config.authenLifeTime } })
);
app.use(passport.initialize());
app.use(passport.session());
/// Body Parser setup
app.use(bodyParser.urlencoded({ extended: false }));
app.use(bodyParser.json());
/// JWT setup
app.set("superSecret", config.JWTKey);
/// morgan setup
app.use(morgan("dev"));
/* GET home page. */
app.get("/", function(req, res, next) {
// res.json({ sucess: true });
if (req.isAuthenticated()) {
res.render("index/home");
} else {
res.redirect("/login");
}
});
app
.route("/login")
.get(function(req, res, next) {
// console.log(req.flash("message"));
if (req.isAuthenticated()) {
res.redirect("/");
} else {
res.render("user/login", { alert: req.session.message || [] });
}
})
.post(
passport.authenticate("local", {
failureRedirect: "/login",
successRedirect: "/"
})
);
passport.use(
new LocalStrategy((username, password, done) => {
fs.readFile("database/user.json", (err, data) => {
if (err) {
return done(err);
}
var db = null;
if (typeof data !== "undefined" && data !== "undefined") {
db = JSON.parse(data);
const userRecord = db.find(account => account.usr == username);
if (userRecord && userRecord.pwd == password) {
return done(null, userRecord);
} else {
return done(null, false, {
message: "Incorrect username or password."
});
}
}
});
})
);
passport.serializeUser((user, done) => {
done(null, user.usr);
});
passport.deserializeUser(function(usrname, done) {
fs.readFile("database/user.json", (err, data) => {
if (err) {
return done(err);
}
var db = null;
if (typeof data !== "undefined" && data !== "undefined") {
db = JSON.parse(data);
const userRecord = db.find(account => (account.usr = usrname));
if (userRecord) {
return done(null, userRecord);
} else {
return done(null, false);
}
}
});
});
// catch 404 and forward to error handler
app.use(function(req, res, next) {
next(createError(404));
});
// error handler
app.use(function(err, req, res, next) {
// set locals, only providing error in development
console.log(err);
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.listen(3000, process.env.IP, function() {
console.log("Visit server at: " + process.env.PORT);
});