Używam tego rozwiązania. Otrzymuję token jwt w body req i stamtąd otrzymuję informacje o roli
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 }
Najpierw używam oprogramowania pośredniego uwierzytelniania, aby wiedzieć, czy jest prawidłowym użytkownikiem, a następnie oprogramowania pośredniczącego roli, aby wiedzieć, czy użytkownik ma dostęp do trasy interfejsu API
router.post('/v1/something-protected', requireAuth, checkRole('commercial'), (req, res) => {
})
Mam nadzieję, że będę przydatny