Software: Apache. PHP/8.1.30 uname -a: Linux server1.tuhinhossain.com 5.15.0-163-generic #173-Ubuntu SMP Tue Oct 14 17:51:00 UTC uid=1002(picotech) gid=1003(picotech) groups=1003(picotech),0(root) Safe-mode: OFF (not secure) /home/picotech/domains/rentals.picotech.app/public_html/server/middleware/ drwxr-xr-x | |
| Viewing file: Select action/file-type: import jwt from 'jsonwebtoken';
import { User } from '../models/index.js';
const auth = async (req, res, next) => {
try {
const token = req.header('Authorization')?.replace('Bearer ', '');
if (!token) {
return res.status(401).json({ message: 'No token, authorization denied' });
}
const decoded = jwt.verify(token, process.env.JWT_SECRET);
const user = await User.findByPk(decoded.id);
if (!user || !user.is_active) {
return res.status(401).json({ message: 'Token is not valid' });
}
req.user = user;
next();
} catch (error) {
res.status(401).json({ message: 'Token is not valid' });
}
};
const authorize = (permissions) => {
return (req, res, next) => {
if (!req.user) {
return res.status(401).json({ message: 'Access denied' });
}
const userPermissions = req.user.permissions || [];
const hasPermission = permissions.some(permission =>
userPermissions.includes(permission) || req.user.role === 'admin' || req.user.role === 'renter'
);
if (!hasPermission) {
return res.status(403).json({ message: 'Insufficient permissions' });
}
next();
};
};
export { auth, authorize }; |
:: Command execute :: | |
--[ c99shell v. 2.5 [PHP 8 Update] [24.05.2025] | Generation time: 0.0037 ]-- |