space-smasher-9001/server/server.js

129 lines
2.5 KiB
JavaScript
Raw Normal View History

2021-10-17 18:57:26 +02:00
import 'dotenv/config'
2021-10-17 18:48:39 +02:00
2021-10-17 20:55:00 +02:00
import express from 'express'
import jwt from 'jsonwebtoken'
2021-10-17 21:45:05 +02:00
import morgan from 'morgan'
2021-10-17 22:17:18 +02:00
import cors from 'cors'
2021-10-17 21:45:05 +02:00
2021-10-17 20:55:00 +02:00
import auth from './Auth.js'
import db from './Database.js'
2021-10-17 23:47:52 +02:00
import jg from './JusticeGuard.js'
2021-10-17 20:55:00 +02:00
2023-03-01 03:36:49 +01:00
const router = express.Router();
2021-10-17 20:55:00 +02:00
const protect = (req, res, next) => {
const authHeader = req.headers.authorization;
if (!authHeader) {
res.sendStatus(401)
}
const token = authHeader.split(' ')[1];
jwt.verify(token, process.env.secret, (err, user) => {
if (err)
return res.sendStatus(403)
req.user = user
next()
})
}
2021-10-17 22:53:33 +02:00
const neededArguments = (args) => {
return (req, res, next) => {
for (let i = 0; i < args.length; i++) {
const arg = args[i];
if (!req.body[arg])
return res.status(400).json({
error: "missing argument " + arg
})
}
next()
}
}
2021-10-17 18:57:26 +02:00
const app = express()
2021-10-17 21:45:05 +02:00
app.use(morgan('combined'))
2021-10-17 22:17:18 +02:00
app.use(cors())
2021-10-17 20:55:00 +02:00
2023-03-01 03:36:49 +01:00
router.use(express.json())
router.get("/", (_, res) => {
2021-10-17 20:55:00 +02:00
res.json({ message: "Hello! API here" })
});
2023-03-01 03:36:49 +01:00
router.get("/secured", protect, (req, res) => {
2021-10-17 20:55:00 +02:00
res.json({ message: "You can see it!", payload: req.user })
})
2023-03-01 03:36:49 +01:00
router.post("/signup", neededArguments(['name']), async (req, res) => {
2021-10-17 21:12:42 +02:00
const user = await auth.createAccount(req.body.name)
2021-10-17 20:55:00 +02:00
2021-10-17 21:12:42 +02:00
if (user.error)
2021-10-17 20:55:00 +02:00
return res.status(400).json({
2021-10-17 21:12:42 +02:00
error: user.error
2021-10-17 20:55:00 +02:00
})
2021-10-17 21:12:42 +02:00
res.json(user)
})
2023-03-01 03:36:49 +01:00
router.post("/login", neededArguments(['key']), async (req, res) => {
2021-10-17 22:53:33 +02:00
const user = auth.login(req.body.key)
2021-10-17 21:12:42 +02:00
if (user.error)
return res.status(400).json({
error: user.error
})
res.json(user)
2021-10-17 20:55:00 +02:00
})
2021-10-17 18:48:39 +02:00
2023-03-01 03:36:49 +01:00
router.post("/record", protect, neededArguments(['points', 'shoots', 'time']), jg, async (req, res) => {
2021-10-17 23:00:29 +02:00
db.updateRecord(req.user.name, req.body.points)
2021-10-18 00:44:02 +02:00
const rank = db.getRank(req.user.name)
console.log(req.user, rank)
2021-10-17 23:00:29 +02:00
res.json({
2021-10-18 00:44:02 +02:00
status: "ok",
rank: rank
2021-10-17 23:00:29 +02:00
})
})
2023-03-01 03:36:49 +01:00
router.get("/top", (req, res) => {
2021-10-17 23:55:58 +02:00
res.json({
status: "ok",
records: db.getTop()
})
})
2023-03-01 03:36:49 +01:00
router.get("/start", protect, async (req, res) => {
2021-10-18 02:33:29 +02:00
await db.setLastPlayedToNow(req.user.name)
res.json({
status: "ok"
})
})
2023-03-01 03:36:49 +01:00
if (process.env.STATIC) {
app.use(express.static(process.env.STATIC));
app.use("/api", router);
} else {
app.use("/", router);
}
2021-10-17 20:55:00 +02:00
app.use(function (err, req, res, next) {
if (err.name === 'UnauthorizedError') {
res.status(401).send('invalid token...');
}
2021-10-17 18:48:39 +02:00
});
2023-03-01 03:36:49 +01:00
(async function () { await db.read() })()
2021-10-18 03:09:28 +02:00
const port = process.env.PORT || 3000
app.listen(port, () => {
console.log(`Server listening on port ${port}!`);
})