Я використовую це рішення. Я отримую маркер jwt у запиті body та отримую інформацію про ролі звідти
const checkRole = role => {
return (req, res, next) => {
if (req.role == role) {
console.log(`${role} role granted`)
next()
} else {
res.status(401).send({ result: 'error', message: `No ${role} permission granted` })
}
}
}
module.exports = { checkRole }
Отже, спочатку я використовую проміжне програмне забезпечення auth, щоб дізнатись, чи є дійсним користувачем, а потім проміжне програмне забезпечення ролі, щоб дізнатися, чи має користувач доступ до маршруту api
router.post('/v1/something-protected', requireAuth, checkRole('commercial'), (req, res) => {
})
Я сподіваюся бути корисним