retropilot-server/src/server/router/api/admin.js

99 lines
3.1 KiB
JavaScript
Raw Normal View History

2022-01-12 08:02:30 -07:00
import express from 'express';
import controllers from '../../controllers';
2021-08-14 16:11:32 -06:00
2022-01-12 08:02:30 -07:00
const router = express.Router();
2021-08-14 16:11:32 -06:00
function runAsyncWrapper(callback) {
return function wrapper(req, res, next) {
2022-01-08 13:43:57 -07:00
callback(req, res, next)
.catch(next);
};
2021-08-14 16:11:32 -06:00
}
// probs should put middleware somewhere else
2022-01-08 13:43:57 -07:00
router.use(async (req, res, next) => {
const currentAdmin = await controllers.admin.isCurrentUserAdmin(true, req);
if (!currentAdmin.account) {
return res.status(401).json({ error: true, msg: 'UNAUTHORISED', status: 401 }).end();
2022-01-08 13:43:57 -07:00
}
if (!currentAdmin.isAdmin) {
return res.status(403).json({ error: true, msg: 'FORBIDDEN', status: 403 }).end();
}
return next();
});
2021-08-14 16:11:32 -06:00
2022-01-08 13:43:57 -07:00
// TODO
router.get('/user/:userId/ban/:ban', runAsyncWrapper(async (req, res) => {
2022-01-08 13:43:57 -07:00
const banResult = await controllers.admin.banAccount(req.params.ban, req.params.userId);
if (!banResult.success) {
return res.status(500).json(banResult);
2022-01-08 13:43:57 -07:00
}
return res.status(200).json(banResult);
}));
router.get('/user/:userId/get/devices', runAsyncWrapper(async (req, res) => {
if (!req.params.userId) {
return req.status(400).json({ error: true, msg: 'MISSING DATA', status: 400 });
}
return res.status(200).json({
success: true,
data: controllers.devices.getDevices(req.params.userId),
});
}));
router.get('/user/', runAsyncWrapper(async (req, res) => {
2022-01-08 13:43:57 -07:00
return res.status(200).json({ success: true, data: await controllers.users.getAllUsers() });
}));
router.get('/device/:dongle_id', runAsyncWrapper(async (req, res) => {
const { dongle_id: dongleId } = req.params;
if (!dongleId) {
return req.status(400).json({ error: true, msg: 'MISSING DATA', status: 400 });
}
2022-03-22 09:14:08 -06:00
const device = await controllers.devices.getDeviceFromDongleId(dongleId);
return res.status(200).json({ success: true, data: device });
}));
2021-10-25 15:56:40 -06:00
router.get('/device/:dongle_id/pair/:user_id', runAsyncWrapper(async (req, res) => {
const { dongle_id: dongleId, user_id: userId } = req.params;
if (!dongleId || !userId) {
return req.status(400).json({ error: true, msg: 'MISSING DATA', status: 400 });
}
const pairDeviceToAccountId = await controllers.devices.pairDeviceToAccountId(dongleId, userId);
2022-01-08 13:43:57 -07:00
return res.status(200).json(pairDeviceToAccountId);
}));
2021-10-25 15:56:40 -06:00
router.get('/device', runAsyncWrapper(async (req, res) => {
2022-01-08 13:43:57 -07:00
const filteredDevices = await controllers.devices.getAllDevicesFiltered();
return res.status(200).json({ success: true, data: filteredDevices });
2021-10-25 15:56:40 -06:00
}));
2021-10-25 15:56:40 -06:00
router.get('/device/:dongle_id/ignore/:ignore_uploads', runAsyncWrapper(async (req, res) => {
const { dongle_id: dongleId, ignore_uploads: ignoreUploads } = req.params;
if (!dongleId || !ignoreUploads) {
return req.status(400).json({ error: true, msg: 'MISSING DATA', status: 400 });
}
2022-01-08 13:43:57 -07:00
// TODO make this cleaner
let isIgnored = null;
switch (ignoreUploads) {
2022-01-08 13:43:57 -07:00
case 'true':
isIgnored = true;
2022-01-08 13:43:57 -07:00
break;
case 'false':
isIgnored = false;
2022-01-08 13:43:57 -07:00
break;
default:
return res.json({ error: true, msg: 'MISSING DATA' });
}
await controllers.devices.setIgnoredUploads(req.params.dongle_id, isIgnored);
2022-01-08 13:43:57 -07:00
return res.status(200).json({ success: true });
2021-08-14 16:11:32 -06:00
}));
2022-01-12 08:02:30 -07:00
export default router;