-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
102 lines (94 loc) · 2.5 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
const env = require('dotenv').config({})
process.env = {...process.env,...require('dotenv-parse-variables')(env.parsed)};
const express = require("express")
const bodyParser = require('body-parser');
const { registraion, auth } = require('./service/auth-service');
const apiErrorMiddleware = require("./middlewares/api-error-middleware");
const unfindMiddleware = require("./middlewares/404-middleware")
const isAuth = require("./middlewares/isAuth-middleware")
const session = require('express-session');
const { getUserByToken } = require('./service/api-service');
const app = express();
app.set("view engine","ejs")
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({extended: true}));
app.use(session({
secret: process.env.sessionSecret,
}))
app.use(express.static("public"))
app.post("/registration", async (req,res,next)=>{
try{
const {email, password, passwordConfirm} = req.body;
const Data = await registraion(email,password,passwordConfirm)
req.session.userId = Data.id;
req.session.email = email;
res.json(Data)
}catch(e){
next(e)
}
})
app.post("/auth", async (req,res,next)=>{
try{
const {email, password} = req.body;
const data = await auth(email,password)
req.session.userId = data.id;
req.session.email = email;
req.session.save()
res.json(data)
}catch(e){
next(e)
}
})
app.get("/getUserByToken", async (req,res,next)=>{
try{
const {token} = req.body;
const data = await getUserByToken(token)
res.json(data)
}catch(e){
next(e)
}
})
app.use(apiErrorMiddleware)
app.get("/info",(req,res)=>{
res.json({userId:req.session.userId})
})
app.get("/registration",(req,res)=>{
res.render("registration")
})
app.get("/auth",(req,res)=>{
res.render("auth")
})
app.get("/",(req,res)=>{
res.redirect("/registration")
})
app.get("/logout",(req,res)=>{
delete req.session.id
res.send("успешно вышли")
})
app.get("/v1/car",(req,res)=>{
res.json(JSON.parse(`
[{
"id": 1,
"model": "m3",
"price": 10000000,
"power": 500,
"description": null,
"brandName": "BMW"
}, {
"id": 2,
"model": "m2 competition",
"price": 100000000,
"power": 1000,
"description": null,
"brandName": "BMW"
}
]
`))
})
app.get("/car",(req,res)=>{
res.render("car")
})
app.get("*",(req,res)=>{
res.render("404")
})
app.listen(process.env.port)