Пользуюсь этим решением. Я получаю токен jwt в теле req и получаю оттуда информацию о ролях
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) => {
})
Я надеюсь быть полезным