Software: Apache. PHP/8.1.30 uname -a: Linux server1.tuhinhossain.com 5.15.0-151-generic #161-Ubuntu SMP Tue Jul 22 14:25:40 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' ); 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.0035 ]-- |