added data sharing between session and socket
This commit is contained in:
parent
f24bbf2daf
commit
ecc319b529
23
backend/controllers/serverController.js
Normal file
23
backend/controllers/serverController.js
Normal 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 };
|
||||||
@ -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,
|
||||||
|
},
|
||||||
|
updatedDoc,
|
||||||
|
function (err, doc) {
|
||||||
if (err) {
|
if (err) {
|
||||||
console.log(err)
|
console.log(err);
|
||||||
}
|
} else {
|
||||||
else{
|
|
||||||
console.log("Updated Docs : ", doc);
|
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
|
|
||||||
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;
|
module.exports = router;
|
||||||
@ -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");
|
|
||||||
});
|
|
||||||
|
|||||||
14
src/App.js
14
src/App.js
@ -19,15 +19,11 @@ 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);
|
|
||||||
});
|
});
|
||||||
}, []);
|
}, []);
|
||||||
|
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user