-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.js
125 lines (111 loc) · 3.38 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
var express = require("express");
var path = require("path");
var cookieParser = require("cookie-parser");
var logger = require("morgan");
var cors = require("cors");
const mongoose = require("mongoose");
const passport = require("passport");
const session = require("express-session");
const bcrypt = require("bcryptjs");
const User = require("./models/user");
const initializePassport = require("./passportConfig.js");
var indexRouter = require("./routes/index");
// var usersRouter = require("./routes/users");
import vehiclesRouter from "./routes/vehicles";
var assetsRouter = require("./routes/assets");
var app = express();
const port = process.env.PORT || 9000;
const whitelist = ["http://localhost:3000", "https://www.mayfairmotorco.com"];
app.use(logger("dev"));
app.use(express.urlencoded({ extended: true }));
app.use(express.json());
app.use(
cors({
origin: function (origin, callback) {
if (whitelist.indexOf(origin) !== -1 || !origin) {
callback(null, true);
} else {
callback(new Error("Not allowed by CORS"));
}
}, // <-- location of the react app were connecting to
credentials: true,
methods: "GET,HEAD,PUT,PATCH,POST,DELETE",
})
);
app.use(cookieParser());
app.use(express.static(path.join(__dirname, "public")));
mongoose
.connect(
process.env.MONGO_URI,
{ useNewUrlParser: true },
{ useUnifiedTopology: true }
)
.then(() => {
app.listen(port, function () {
console.log("RUNNING ON PORT 9000");
});
});
app.use(
session({
secret: "secretcode",
resave: true,
saveUninitialized: true,
// cookie: {
// maxAge: 1000 * 60 * 60 * 24, // one day
// },
})
);
app.use(cookieParser("secretcode"));
app.disable("etag");
// Passport setup
app.use(passport.initialize());
app.use(passport.session());
initializePassport(passport);
app.post("/users/login", (req, res, next) => {
passport.authenticate("local", (err, user, info) => {
if (err) throw err;
if (!user) res.status(500).send("No User");
else {
req.logIn(user, (err) => {
if (err) throw err;
console.log("AUTHED:", req.isAuthenticated());
res.send({ status: "USER SUCCESSFULLY AUTHENTICATED", user });
});
}
})(req, res, next);
});
app.post("/users/register", (req, res) => {
User.findOne({ username: req.body.username }, async (err, doc) => {
if (err) throw err;
if (doc) res.send("User Already Exists");
if (!doc) {
const hashedPassword = await bcrypt.hash(req.body.password, 10);
const newUser = new User({
username: req.body.username,
password: hashedPassword,
});
await newUser.save();
res.send("User Created");
}
});
});
// Visiting this route logs the user out
app.get("/users/logout", (req, res, next) => {
req.logout();
res.status(200).send("Logout Successful");
});
app.get("/users/authed-user", (req, res) => {
console.log("AUTHED-USER:", req.isAuthenticated());
if (req) res.status(200).json({ isAuthed: req.isAuthenticated() }); // The req.user stores the entire user that has been authenticated inside of it.
});
function checkAuthenticated(req, res, next) {
console.log("IS AUTHED", req.isAuthenticated());
if (req.isAuthenticated()) {
return next();
}
}
app.use("/", indexRouter);
// app.use("/users", usersRouter);
app.use("/vehicles", vehiclesRouter);
app.use("/assets", assetsRouter);
module.exports = app;