added data sharing between session and socket

This commit is contained in:
Wenszel 2022-05-28 22:54:23 +02:00
parent f24bbf2daf
commit ecc319b529
4 changed files with 92 additions and 107 deletions

View File

@ -0,0 +1,23 @@
const session = require("express-session");
const CONNECTION_URI = require("../credentials.js");
const MongoDBStore = require("connect-mongodb-session")(session);
const store = new MongoDBStore({
uri: CONNECTION_URI,
collection: "sessions",
});
const sessionMiddleware = session({
secret: "lalala",
resave: true,
saveUninitialized: false,
store: store,
credentials: true,
cookie: {
httpOnly: false,
secure: false,
},
});
const wrap = (expressMiddleware) => (socket, next) =>
expressMiddleware(socket.request, {}, next);
module.exports = { sessionMiddleware, wrap };

View File

@ -1,65 +1,54 @@
var express = require('express'); var express = require("express");
var router = express.Router(); var router = express.Router();
var RoomModel = require('../schemas/room'); var RoomModel = require("../schemas/room");
var changeReadyState = (req, res, exit) =>{ var changeReadyState = (req, res, exit) => {
RoomModel.findOne({_id: req.session.roomId}, function (err, doc){ RoomModel.findOne({ _id: req.session.roomId }, function (err, doc) {
if (err) { if (err) {
res.status(500).send(err) res.status(500).send(err);
} else { } else {
//finds player by id and changes ready state //finds player by id and changes ready state
let updatedPlayers = doc.players; let updatedPlayers = doc.players;
let index = updatedPlayers.findIndex( let index = updatedPlayers.findIndex(
player => (player._id).toString() == (req.session.playerId).toString() (player) => player._id.toString() == req.session.playerId.toString()
); );
if(!exit) updatedPlayers[index].ready = !updatedPlayers[index].ready; if (!exit) updatedPlayers[index].ready = !updatedPlayers[index].ready;
else updatedPlayers[index].ready = false; else updatedPlayers[index].ready = false;
const updatedDoc = { const updatedDoc = {
players: updatedPlayers players: updatedPlayers,
} };
if(updatedPlayers.filter(player => player.ready).length >= 2){ if (updatedPlayers.filter((player) => player.ready).length >= 2) {
updatedDoc.started = true; updatedDoc.started = true;
updatedDoc.players.forEach(player => player.ready = true); updatedDoc.players.forEach((player) => (player.ready = true));
updatedDoc.nextMoveTime = Date.now() + 15000; updatedDoc.nextMoveTime = Date.now() + 15000;
updatedDoc.players[0].nowMoving = true; updatedDoc.players[0].nowMoving = true;
} }
RoomModel.findOneAndUpdate({ RoomModel.findOneAndUpdate(
_id: req.session.roomId {
}, updatedDoc, function(err, doc){ _id: req.session.roomId,
if (err){ },
console.log(err) updatedDoc,
} function (err, doc) {
else{ if (err) {
console.log("Updated Docs : ", doc); console.log(err);
} } else {
}); console.log("Updated Docs : ", doc);
res.status(200).send("Ready!"); }
} }
}); );
} res.status(200).send("Ready!");
}
});
};
//changing status of player to ready for game //changing status of player to ready for game
router.post('/ready', function (req, res){ router.post("/ready", function (req, res) {
changeReadyState(req, res, false) changeReadyState(req, res, false);
}); });
//deleting user in case he left before game started //deleting user in case he left before game started
router.post('/exit', function(req,res){ router.post("/exit", function (req, res) {
// changeReadyState(req,res, true) // changeReadyState(req,res, true)
}); });
//return session data module.exports = router;
router.get('/', (req,res)=>{
// If session exist return sessions data to move player to game when he backs to site
if(req.session){
res.send({
color: req.session.color,
playerId: req.session.playerId,
roomId: req.session.roomId,
})
}else{
res.end();
}
});
module.exports = router;

View File

@ -1,8 +1,7 @@
const express = require("express"); const express = require("express");
const cors = require("cors"); const cors = require("cors");
const cookieParser = require("cookie-parser"); const cookieParser = require("cookie-parser");
const session = require("express-session"); const { sessionMiddleware, wrap } = require("./controllers/serverController");
const app = express(); const app = express();
app.use(cookieParser()); app.use(cookieParser());
app.use( app.use(
@ -14,17 +13,12 @@ app.use(express.json());
app.set("trust proxy", 1); app.set("trust proxy", 1);
app.use( app.use(
cors({ cors({
origin: [ origin: "http://localhost:3000",
"http://localhost:5000",
"https://localhost:5000",
"http://localhost:3001",
"http://localhost:3000",
],
credentials: true, credentials: true,
}) })
); );
const PORT = 5000; const PORT = 5000;
app.use(sessionMiddleware);
//DATABASE CONFIG //DATABASE CONFIG
const mongoose = require("mongoose"); const mongoose = require("mongoose");
mongoose.set("useFindAndModify", false); mongoose.set("useFindAndModify", false);
@ -40,24 +34,7 @@ mongoose
}) })
.catch((err) => console.error(err)); .catch((err) => console.error(err));
//SESSION CONFIG] //SESSION CONFIG
var MongoDBStore = require("connect-mongodb-session")(session);
var store = new MongoDBStore({
uri: CONNECTION_URI,
collection: "sessions",
});
app.use(
session({
secret: "lalala",
resave: true,
saveUninitialized: false,
store: store,
cookie: {
httpOnly: false,
secure: false,
},
})
);
if (process.env.NODE_ENV === "production") { if (process.env.NODE_ENV === "production") {
app.use(express.static("/app/build")); app.use(express.static("/app/build"));
@ -65,6 +42,19 @@ if (process.env.NODE_ENV === "production") {
res.sendFile("/app/build/index.html"); res.sendFile("/app/build/index.html");
}); });
} }
const server = app.listen(PORT, () => {
console.log("Server runs on port " + PORT);
});
const io = require("socket.io")(server, {
cors: {
origin: "http://localhost:3000",
credentials: true,
},
});
io.use(wrap(sessionMiddleware));
io.on("connection", (socket) => {
socket.emit("client data", JSON.stringify(socket.request.session));
});
//ROUTES CONFIG //ROUTES CONFIG
const roomRoutes = require("./routes/room"); const roomRoutes = require("./routes/room");
@ -74,16 +64,3 @@ const gameRoutes = require("./routes/game");
app.use("/player", playerRoutes); app.use("/player", playerRoutes);
app.use("/room", roomRoutes); app.use("/room", roomRoutes);
app.use("/game", gameRoutes); app.use("/game", gameRoutes);
const server = app.listen(PORT, () => {
console.log("Server runs on port " + PORT);
});
const socket = require("socket.io");
const io = socket(server, {
cors: {
origin: "http://localhost:3000",
},
});
io.on("connection", () => {
console.log("a user connected");
});

View File

@ -19,16 +19,12 @@ function App() {
const [redirect, setRedirect] = useState(); const [redirect, setRedirect] = useState();
useEffect(() => { useEffect(() => {
const socket = io("http://localhost:5000"); const socket = io("http://localhost:5000", { withCredentials: true });
socket.on("connect", () => console.log(socket.id)); socket.on("client data", (data) => {
axios data = JSON.parse(data);
.get("/player", { setPlayerData(data);
withCredentials: true, data.roomId != null ? setRedirect(true) : setRedirect(false);
}) });
.then((response) => {
setPlayerData(response.data);
response.data.roomId != null ? setRedirect(true) : setRedirect(false);
});
}, []); }, []);
const handleExit = (e) => { const handleExit = (e) => {