/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);
    }
}