/home2/mshostin/hall-management.ms-hostingladz.com/app/Http/Middleware/PermissionMiddleware.php
<?php
namespace App\Http\Middleware;
use Closure;
use Illuminate\Http\Request;
use Illuminate\Support\Str;
class PermissionMiddleware
{
public function handle(Request $request, Closure $next, string $permissions)
{
$user = $request->user();
if (!$user) {
abort(403, 'Forbidden');
}
if ($request->has('status') && !empty($request->status)) {
$status = Str::title(str_replace('-', ' ', $request->status));
if (!$user->hasRole('super_admin')) {
$allowedStatuses = $user->allPermissions()
->filter(fn($perm) => str_starts_with($perm->slug, 'view-quotes-'))
->pluck('slug')
// ->map(fn($slug) => Str::title(str_replace('view-quotes-', '', $slug)))
->map(function ($slug) {
$clean = preg_replace('/[^a-z0-9\-]/i', '', str_replace('view-quotes-', '', $slug));
return Str::title(str_replace('-', ' ', $clean));
})
->toArray();
if (!in_array($status, $allowedStatuses)) {
abort(403, 'Forbidden');
}
}
}
if (!empty($permissions) && !$user->hasRole('super_admin')) {
$required = array_filter(array_map('trim', explode(',', $permissions)));
if (!$user->hasAllPermissions($required)) {
abort(403, 'Forbidden');
}
}
return $next($request);
}
}