Fix jwt-token

This commit is contained in:
2025-09-19 07:33:23 +02:00
parent a575e39970
commit f98fd04191
3 changed files with 100 additions and 20 deletions

View File

@@ -67,14 +67,20 @@ async function authenticateToken(req, res, next) {
if (!user) {
return res.status(401).json({
success: false,
message: 'User not found'
message: 'User account not found. Please contact support.',
error: 'USER_NOT_FOUND',
errorCode: 'USER_NOT_FOUND',
redirectToLogin: true
});
}
if (!user.is_active) {
return res.status(401).json({
success: false,
message: 'User account is inactive'
message: 'Your account has been deactivated. Please contact support.',
error: 'ACCOUNT_DEACTIVATED',
errorCode: 'ACCOUNT_INACTIVE',
redirectToLogin: true
});
}
@@ -158,7 +164,10 @@ function requireRole(roles) {
if (!req.user) {
return res.status(401).json({
success: false,
message: 'Authentication required'
message: 'Authentication required',
error: 'NO_AUTH',
errorCode: 'AUTH_REQUIRED',
redirectToLogin: true
});
}
@@ -166,7 +175,12 @@ function requireRole(roles) {
if (!userRoles.includes(req.user.role)) {
return res.status(403).json({
success: false,
message: 'Insufficient permissions'
message: `Access denied. This action requires ${userRoles.join(' or ')} permissions, but you have ${req.user.role} permissions.`,
error: 'INSUFFICIENT_PERMISSIONS',
errorCode: 'PERMISSION_DENIED',
userRole: req.user.role,
requiredRoles: userRoles,
redirectToLogin: false // Don't redirect for permission issues
});
}