Files
L-Ami-Fiduciaire/app/Http/Middleware/HandleInertiaRequests.php
Saad Ibn-Ezzoubayr c89d1879bf feat: complete Epic 1 — team management & permission system
- Story 1.1: Permission enum, config, AuthorizesPermissions & HasWorkspaceScope traits, member→worker migration
- Story 1.2: Team page with member list, invitation system with queued email
- Story 1.3: Role assignment (Manager/Worker) and member removal with activity logging
- Story 1.4: Owner-only permission toggle matrix for Managers (manage team, view logs, configure portal)
- Story 1.5: Role-based access enforcement — Workers see only assigned declarations/clients, sidebar scoping
- Story 1.6: Workspace switcher dropdown for multi-workspace users with session-based switching
- 83 new/modified files, 182 tests passing with zero regressions

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-18 00:12:50 +00:00

112 lines
3.8 KiB
PHP

<?php
namespace App\Http\Middleware;
use App\Models\WorkspaceUser;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Cache;
use Inertia\Inertia;
use Inertia\Middleware;
class HandleInertiaRequests extends Middleware
{
/**
* The root template that's loaded on the first page visit.
*
* @see https://inertiajs.com/server-side-setup#root-template
*
* @var string
*/
protected $rootView = 'app';
/**
* Determines the current asset version.
*
* @see https://inertiajs.com/asset-versioning
*/
public function version(Request $request): ?string
{
return parent::version($request);
}
/**
* Define the props that are shared by default.
*
* @see https://inertiajs.com/shared-data
*
* @return array<string, mixed>
*/
public function share(Request $request): array
{
$user = $request->user();
$workspaces = $user
? $user->workspaces()
->orderBy('name')
->get(['workspaces.id', 'workspaces.name', 'workspaces.slug'])
->map(fn ($w) => [
'id' => $w->id,
'name' => $w->name,
'slug' => $w->slug,
])
->values()
->all()
: [];
$currentWorkspaceId = $request->session()->get('current_workspace_id');
$currentWorkspace = collect($workspaces)->firstWhere('id', $currentWorkspaceId)
?? ($workspaces[0] ?? null);
if (! $currentWorkspaceId && count($workspaces) > 0) {
$request->session()->put('current_workspace_id', $currentWorkspace['id']);
}
return [
...parent::share($request),
'flash' => [
'success' => $request->session()->get('success'),
'error' => $request->session()->get('error'),
],
'name' => config('app.name'),
'auth' => [
'user' => $user,
'workspaces' => $workspaces,
'currentWorkspace' => $currentWorkspace,
'workspaceRole' => $user && $currentWorkspace
? WorkspaceUser::where('user_id', $user->id)
->where('workspace_id', $currentWorkspace['id'])
->first()?->role?->value
: null,
'workspaceSwitchUrl' => $user ? route('workspace.switch') : null,
],
'sidebarOpen' => ! $request->hasCookie('sidebar_state') || $request->cookie('sidebar_state') === 'true',
'userNotifications' => [
'unread_count' => $user ? Cache::remember(
"user:{$user->id}:unread_notifications",
60,
fn () => $user->unreadNotifications()->count()
) : 0,
'readUrl' => fn () => $user ? route('notifications.read', ['id' => '__ID__']) : null,
'readAllUrl' => fn () => $user ? route('notifications.readAll') : null,
'items' => Inertia::defer(function () use ($user) {
if (! $user) {
return [];
}
try {
return $user->notifications()->latest()->take(10)->get()->map(fn ($n) => [
'id' => $n->id,
'type' => class_basename($n->type),
'data' => $n->data,
'read_at' => $n->read_at?->toISOString(),
'created_at' => $n->created_at->diffForHumans(),
])->all();
} catch (\Throwable) {
return [];
}
}),
],
];
}
}