add: merged front with back
This commit is contained in:
parent
1832ed12ec
commit
48f50a1daa
42 changed files with 5458 additions and 20 deletions
49
back/api/v1/games/addHelper.js
Normal file
49
back/api/v1/games/addHelper.js
Normal file
|
@ -0,0 +1,49 @@
|
|||
const express = require('express');
|
||||
const jwt = require('jsonwebtoken');
|
||||
|
||||
const { getConnection, addHelper, getGame, getHelpers } = require("../../../libs/mysql.js")
|
||||
|
||||
const router = express.Router();
|
||||
|
||||
router.post('/', async (req, res) => {
|
||||
const {token, gameid} = req.body;
|
||||
|
||||
if (!token) {
|
||||
return res.status(400).send({error: "invalid token"});
|
||||
}
|
||||
|
||||
if (!gameid) {
|
||||
return res.status(400).send({error: "invalid gameid"});
|
||||
}
|
||||
|
||||
try {
|
||||
const user = jwt.verify(token, process.env.JWTSecret);
|
||||
|
||||
if (user.expiration < Date.now()) {
|
||||
return res.status(400).send({error: "token expired"});
|
||||
}
|
||||
|
||||
const connection = await getConnection();
|
||||
const game = await getGame(connection, gameid);
|
||||
|
||||
if (!game[0]) {
|
||||
return res.status(400).send({error: "this game doesn't exist"});
|
||||
}
|
||||
|
||||
const helpers = await getHelpers(connection, gameid);
|
||||
|
||||
if (JSON.stringify(helpers).includes(user.user.id)) {
|
||||
return res.status(400).send({error: "you are already an helper for this game"});
|
||||
}
|
||||
|
||||
await addHelper(connection, gameid, user.user.id);
|
||||
connection.end();
|
||||
} catch (error) {
|
||||
console.log(error);
|
||||
return res.status(400).send({error: "invalid token"});
|
||||
}
|
||||
|
||||
res.status(200).send({message: "success"});
|
||||
});
|
||||
|
||||
module.exports = router;
|
40
back/api/v1/games/getGame.js
Normal file
40
back/api/v1/games/getGame.js
Normal file
|
@ -0,0 +1,40 @@
|
|||
const express = require('express');
|
||||
const jwt = require('jsonwebtoken');
|
||||
|
||||
const { getConnection, getGame } = require("../../../libs/mysql.js")
|
||||
|
||||
const router = express.Router();
|
||||
|
||||
router.post('/', async (req, res) => {
|
||||
const {token, gameid} = req.body;
|
||||
|
||||
if (!token) {
|
||||
return res.status(400).send({error: "invalid token"});
|
||||
}
|
||||
|
||||
if (!gameid) {
|
||||
return res.status(400).send({error: "invalid gameid"});
|
||||
}
|
||||
|
||||
try {
|
||||
const user = jwt.verify(token, process.env.JWTSecret);
|
||||
|
||||
if (user.expiration < Date.now()) {
|
||||
return res.status(400).send({error: "token expired"});
|
||||
}
|
||||
} catch {
|
||||
return res.status(400).send({error: "invalid token"});
|
||||
}
|
||||
|
||||
const connection = await getConnection();
|
||||
const game = await getGame(connection, gameid)
|
||||
connection.end();
|
||||
|
||||
if (!game[0]) {
|
||||
return res.status(400).send({error: "this game doesn't exist in the data base"})
|
||||
};
|
||||
|
||||
res.status(200).send(game[0]);
|
||||
});
|
||||
|
||||
module.exports = router;
|
36
back/api/v1/games/getHelpers.js
Normal file
36
back/api/v1/games/getHelpers.js
Normal file
|
@ -0,0 +1,36 @@
|
|||
const express = require('express');
|
||||
const jwt = require('jsonwebtoken');
|
||||
|
||||
const { getConnection, getHelpers } = require("../../../libs/mysql.js")
|
||||
|
||||
const router = express.Router();
|
||||
|
||||
router.post('/', async (req, res) => {
|
||||
const {token, gameid} = req.body;
|
||||
|
||||
if (!token) {
|
||||
return res.status(400).send({error: "invalid token"});
|
||||
}
|
||||
|
||||
if (!gameid) {
|
||||
return res.status(400).send({error: "invalid gameid"});
|
||||
}
|
||||
|
||||
try {
|
||||
const user = jwt.verify(token, process.env.JWTSecret);
|
||||
|
||||
if (user.expiration < Date.now()) {
|
||||
return res.status(400).send({error: "token expired"});
|
||||
}
|
||||
} catch {
|
||||
return res.status(400).send({error: "invalid token"});
|
||||
}
|
||||
|
||||
const connection = await getConnection();
|
||||
const helpers = await getHelpers(connection, gameid)
|
||||
connection.end();
|
||||
|
||||
res.status(200).send(helpers);
|
||||
});
|
||||
|
||||
module.exports = router;
|
31
back/api/v1/games/getall.js
Normal file
31
back/api/v1/games/getall.js
Normal file
|
@ -0,0 +1,31 @@
|
|||
const express = require('express');
|
||||
const jwt = require('jsonwebtoken');
|
||||
|
||||
const { getConnection, getGames } = require("../../../libs/mysql.js")
|
||||
|
||||
const router = express.Router();
|
||||
|
||||
router.post('/', async (req, res) => {
|
||||
const {token} = req.body;
|
||||
|
||||
if (!token) {
|
||||
return res.status(400).send({error: "invalid token"});
|
||||
}
|
||||
|
||||
try {
|
||||
const user = jwt.verify(token, process.env.JWTSecret);
|
||||
|
||||
if (user.expiration < Date.now()) {
|
||||
return res.status(400).send({error: "token expired"});
|
||||
}
|
||||
} catch {
|
||||
return res.status(400).send({error: "invalid token"});
|
||||
}
|
||||
|
||||
const connection = await getConnection();
|
||||
const games = await getGames(connection);
|
||||
connection.end();
|
||||
res.status(200).send(games);
|
||||
});
|
||||
|
||||
module.exports = router;
|
36
back/api/v1/games/removeHelper.js
Normal file
36
back/api/v1/games/removeHelper.js
Normal file
|
@ -0,0 +1,36 @@
|
|||
const express = require('express');
|
||||
const jwt = require('jsonwebtoken');
|
||||
|
||||
const { getConnection, removeHelper, getHelpers } = require("../../../libs/mysql.js")
|
||||
|
||||
const router = express.Router();
|
||||
|
||||
router.post('/', async (req, res) => {
|
||||
const {token, gameid} = req.body;
|
||||
|
||||
if (!token) {
|
||||
return res.status(400).send({error: "invalid token"});
|
||||
}
|
||||
|
||||
if (!gameid) {
|
||||
return res.status(400).send({error: "invalid gameid"});
|
||||
}
|
||||
|
||||
try {
|
||||
const user = jwt.verify(token, process.env.JWTSecret);
|
||||
|
||||
if (user.expiration < Date.now()) {
|
||||
return res.status(400).send({error: "token expired"});
|
||||
}
|
||||
|
||||
const connection = await getConnection();
|
||||
await removeHelper(connection, gameid, user.user.id)
|
||||
connection.end();
|
||||
} catch {
|
||||
return res.status(400).send({error: "invalid token"});
|
||||
}
|
||||
|
||||
res.status(200).send({message: "success"});
|
||||
});
|
||||
|
||||
module.exports = router;
|
Loading…
Add table
Add a link
Reference in a new issue