-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathindex.js
130 lines (102 loc) · 3.2 KB
/
index.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
128
129
130
const express = require('express');
const StormDB = require("stormdb");
const bcrypt = require("bcrypt");
const session = require("express-session")
var bodyParser = require('body-parser')
const appController = require("./board");
const app = express();
app.use(express.static('views/static'))
app.use(bodyParser.urlencoded({ extended: false }))
app.use(bodyParser.json())
app.set('view engine', 'ejs');
const engine = new StormDB.localFileEngine("./db.stormdb");
const db = new StormDB(engine);
app.use("/imghost", express.static('imghost'))
app.use(
session({
secret: "Platypuses are really cool",
resave: false,
saveUninitialized: false,
})
)
app.get("/",(req,res) => {
if (req.session.username) {
userdb = db.get().state.users
res.render("default/mainlogged", {userName: req.session.username, userdb: userdb})
} else {
console.log(req.session)
res.render("default/main")
}
})
app.get("/login",(req,res) => {
const error = req.session.error;
delete req.session.error;
res.render("default/login", { err: error });
})
app.post("/login",async (req,res) => {
const { name, password } = req.body;
console.log(req.body)
console.log(req.session)
const user = db.get().state.users.find(o => o.name === name);
console.log(user)
if (!user) {
req.session.error = "Invalid Credentials";
return res.redirect("/login");
}
const isMatch = await bcrypt.compare(password, user.password);
if (!isMatch) {
req.session.error = "Invalid Credentials";
return res.redirect("/login");
}
req.session.isAuth = true;
req.session.username = user.name;
res.redirect("/");
})
app.get("/register",(req,res) => {
const error = req.session.error;
delete req.session.error;
res.render("default/register", { err: error });
})
app.post("/register",async (req,res) => {
const { username, email, password } = req.body;
console.log(req.session)
const user = db.get().state.users.find(o => o.email === email);
if (user) {
req.session.error = "User Already Exists";
return res.redirect("default/register");
}
const hasdPsw = await bcrypt.hash(password, 12);
db.get("users").push({"name":username,"email":email,"password": hasdPsw})
db.save()
res.redirect("/login")
})
app.get("/img", appController.img_get);
app.get("/msg", appController.msg_get);
app.get("/imgupload", appController.imgupload_get);
app.get("/msgupload", appController.msgupload_get);
app.post("/imgupload", appController.imgupload_post);
app.post("/msgupload", appController.msgupload_post);
/* app.post("/delete",(req,res) => {
const {type, content, pass} = req.body
if (pass === process.env.DELKEY) {
if (type === "img") {
target = db.get().state.img.findIndex((i) => i.imgname === content)
db.get("img").get(target).delete(true)
db.save()
res.send("Deleted Image")
} else if (type === "msg") {
target = db.get().state.msg.findIndex((i) => i.msg === content)
db.get("msg").get(target).delete(true)
db.save()
res.send("Deleted Message")
}
} else {
res.send("Nice try")
}
if (!type || !content || !pass) {
res.send("type, content, pass required")
}
}) */
app.listen(3002, () => {
console.log('server started');
});