mirror of
https://github.com/bluewave-labs/Checkmate.git
synced 2026-02-12 20:39:28 -06:00
51 lines
1.3 KiB
JavaScript
51 lines
1.3 KiB
JavaScript
const router = require("express").Router();
|
|
const { verifyJWT } = require("../middleware/verifyJWT");
|
|
const { verifyOwnership } = require("../middleware/verifyOwnership");
|
|
const { isAllowed } = require("../middleware/isAllowed");
|
|
const multer = require("multer");
|
|
const upload = multer();
|
|
const User = require("../models/user");
|
|
|
|
const {
|
|
registerController,
|
|
loginController,
|
|
logoutController,
|
|
userEditController,
|
|
recoveryRequestController,
|
|
validateRecoveryTokenController,
|
|
resetPasswordController,
|
|
checkSuperadminController,
|
|
getAllUsersController,
|
|
deleteUserController,
|
|
} = require("../controllers/authController");
|
|
|
|
//Auth routes
|
|
router.post("/register", upload.single("profileImage"), registerController);
|
|
router.post("/login", loginController);
|
|
router.put(
|
|
"/user/:userId",
|
|
upload.single("profileImage"),
|
|
verifyJWT,
|
|
userEditController
|
|
);
|
|
router.get("/users/superadmin", checkSuperadminController);
|
|
router.get(
|
|
"/users",
|
|
verifyJWT,
|
|
isAllowed(["admin", "superadmin"]),
|
|
getAllUsersController
|
|
);
|
|
router.delete(
|
|
"/user/:userId",
|
|
verifyJWT,
|
|
verifyOwnership(User, "userId"),
|
|
deleteUserController
|
|
);
|
|
|
|
//Recovery routes
|
|
router.post("/recovery/request", recoveryRequestController);
|
|
router.post("/recovery/validate", validateRecoveryTokenController);
|
|
router.post("/recovery/reset/", resetPasswordController);
|
|
|
|
module.exports = router;
|