67 lines
4.1 KiB
JavaScript
67 lines
4.1 KiB
JavaScript
/*Canopy - The next generation of stoner streaming software
|
|
Copyright (C) 2024-2025 Rainbownapkin and the TTN Community
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
it under the terms of the GNU Affero General Public License as
|
|
published by the Free Software Foundation, either version 3 of the
|
|
License, or (at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU Affero General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Affero General Public License
|
|
along with this program. If not, see <https://www.gnu.org/licenses/>.*/
|
|
|
|
//npm imports
|
|
const { body, checkExact} = require('express-validator');
|
|
const { Router } = require('express');
|
|
|
|
|
|
//local imports
|
|
const accountValidator = require("../../validators/accountValidator");
|
|
const {permissionsValidator, channelPermissionValidator} = require("../../validators/permissionsValidator");
|
|
const tokebotValidator = require("../../validators/tokebotValidator");
|
|
const emoteValidator = require("../../validators/emoteValidator");
|
|
const permissionSchema = require("../../schemas/permissionSchema");
|
|
const listUsersController = require("../../controllers/api/admin/listUsersController");
|
|
const listChannelsController = require("../../controllers/api/admin/listChannelsController");
|
|
const changeRankController = require("../../controllers/api/admin/changeRankController");
|
|
const permissionsController = require("../../controllers/api/admin/permissionsController");
|
|
const banController = require("../../controllers/api/admin/banController");
|
|
const tokeCommandController = require('../../controllers/api/admin/tokeCommandController');
|
|
const emoteController = require('../../controllers/api/admin/emoteController');
|
|
const passwordResetController = require('../../controllers/api/admin/passwordResetController');
|
|
|
|
//globals
|
|
const router = Router();
|
|
|
|
//routing functions
|
|
//listUsers
|
|
router.get('/listUsers', permissionSchema.reqPermCheck("adminPanel"), listUsersController.get);
|
|
//listChannels
|
|
router.get('/listChannels', permissionSchema.reqPermCheck("adminPanel"), listChannelsController.get);
|
|
//permissions
|
|
router.get('/permissions', permissionSchema.reqPermCheck("adminPanel"), permissionsController.get);
|
|
router.post('/permissions', permissionSchema.reqPermCheck("changePerms"), checkExact([permissionsValidator.permissionsMap(), channelPermissionValidator.channelPermissionsMap()]), permissionsController.post);
|
|
//changeRank
|
|
router.post('/changeRank', permissionSchema.reqPermCheck("changeRank"), accountValidator.user(), accountValidator.rank(), changeRankController.post);
|
|
//Ban
|
|
router.get('/ban', permissionSchema.reqPermCheck("adminPanel"), banController.get);
|
|
//Sometimes they're so simple you don't need to put your validators in their own special place :P
|
|
router.post('/ban', permissionSchema.reqPermCheck("banUser"), accountValidator.user(), body("permanent").isBoolean(), body("expirationDays").isInt(), banController.post);
|
|
router.delete('/ban', permissionSchema.reqPermCheck("banUser"), accountValidator.user(), banController.delete);
|
|
//TokeCommands
|
|
router.get('/tokeCommands', permissionSchema.reqPermCheck("adminPanel"), tokeCommandController.get);
|
|
router.post('/tokeCommands', permissionSchema.reqPermCheck("editTokeCommands"), tokebotValidator.command(), tokeCommandController.post);
|
|
router.delete('/tokeCommands', permissionSchema.reqPermCheck("editTokeCommands"), tokebotValidator.command(), tokeCommandController.delete);
|
|
//emote
|
|
router.get('/emote', permissionSchema.reqPermCheck('adminPanel'), emoteController.get);
|
|
router.post('/emote', permissionSchema.reqPermCheck('editEmotes'), emoteValidator.name(), emoteValidator.link(), emoteController.post);
|
|
router.delete('/emote', permissionSchema.reqPermCheck('editEmotes'), emoteValidator.name(), emoteController.delete);
|
|
//passwordReset
|
|
router.post('/genPasswordReset', permissionSchema.reqPermCheck('genPasswordReset'), accountValidator.user(), passwordResetController.post);
|
|
|
|
module.exports = router;
|