-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.js
93 lines (76 loc) · 2.61 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
import "dotenv/config";
import express from "express";
import passport from "passport";
import cors from "cors";
import morgan from "morgan";
import session from "express-session";
import compression from "compression";
import { Server } from "socket.io";
import passp from "./src/middleware/passport.middleware.js";
import { conn } from "./database/index.js";
import routerAuth from "./src/router/auth.router.js";
import routerFile from "./src/router/image.router.js";
import routerShop from "./src/router/toko.router.js";
import adminRoutes from "./src/router/admin.router.js";
import loginRoutes from "./src/router/authAdmin.router.js";
import routerProduct from "./src/router/product.router.js";
import routerTransaction from "./src/router/transaction.router.js";
import productUserRoutes from "./src/router/user/product.router.js";
import transactionUserRoutes from "./src/router/user/transaction.router.js";
import tokoUserRoutes from "./src/router/user/toko.router.js";
const app = express();
const { PORT } = process.env;
app.use(express.json());
app.use(morgan(`[LOG] ipAddr=:remote-addr date=[:date[web]] time=:response-time ms method=:method url=":url" status=":status" `));
// app.use(
// session({
// secret: "keyboard cat",
// resave: false,
// saveUninitialized: false,
// cookie: { secure: true, maxAge: 1000 * 60 * 100 },
// })
// );
const corsConfig = {
// origin: true,
credentials: true,
};
app.use(cors(corsConfig));
app.options("*", cors(corsConfig));
app.use(function (req, res, next) {
res.header("Access-Control-Allow-Credentials", "true");
next();
});
app.use(compression());
app.use(passport.initialize());
// app.use(passport.session());
passp(passport);
app.get("/", (req, res) => {
res.send("Aktif");
});
app.use("/api/seller/v1/shop", passport.authenticate("jwt", { session: false }), routerShop);
app.use("/api/seller/v1/product", routerProduct);
app.use("/api/seller/v1/transaction", routerTransaction);
app.use("/api/seller/auth", routerAuth);
app.use("/api/seller/file", routerFile);
app.use("/api/admin/v1/data", adminRoutes);
app.use("/api/admin/auth", loginRoutes);
app.use("/api/user/v1/product", productUserRoutes);
app.use("/api/user/v1/toko", tokoUserRoutes);
app.use("/api/user/v1/transaction", transactionUserRoutes);
const server = app.listen(PORT, async () => {
await conn.connectRedis();
console.log(`[SERVER] App Listen PORT : ${PORT}`);
});
const io = new Server(server, {
cors: {
origin: "*",
},
});
const socket = io.on("connection", (sock) => {
console.log("connect");
sock.on("disconnect", () => {
console.log("server disconnect");
});
return sock;
});
export { socket, io };