feat(sidebar) : section Administration + groupe Mon compte + gate de section

- Section "Général" renommée en "Administration" (label i18n sidebar.administration.section).
- Item "Administration" (/admin) retiré : la route n'existait pas cote front, generait un 404 Nuxt silencieux a chaque clic.
- "Deconnexion" sortie de la section admin, deplacee dans une nouvelle section "Mon compte" (sidebar.account.section) sans permission RBAC — accessible a tout user authentifie.
- SidebarProvider supporte desormais un champ `permission` au niveau section : umbrella gate qui masque toute la section et bascule toutes ses routes dans disabledRoutes. Voir doc inline dans config/sidebar.php pour le pattern d'usage.

Avantage : pour gater toute l'administration derriere une permission coarse (ex: 'core.admin.access' future), ajouter 'permission' => 'core.admin.access' sur la section suffit — pas besoin de dupliquer la permission sur chaque item.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
This commit is contained in:
Matthieu
2026-04-22 11:28:44 +02:00
parent 5f5afccac0
commit 701a480442
3 changed files with 74 additions and 25 deletions

View File

@@ -17,7 +17,7 @@ class SidebarProvider implements ProviderInterface
/** @var list<string> */
private readonly array $activeModuleIds;
/** @var list<array{label: string, icon: string, items: list<array{label: string, to: string, icon: string, module: string, permission?: string}>}> */
/** @var list<array{label: string, icon: string, permission?: string, items: list<array{label: string, to: string, icon: string, module: string, permission?: string}>}> */
private readonly array $sidebarConfig;
public function __construct(private readonly Security $security)
@@ -47,6 +47,23 @@ class SidebarProvider implements ProviderInterface
$disabledRoutes = [];
foreach ($this->sidebarConfig as $section) {
// Gate de section (optionnel) : si la section declare une permission
// et que l'utilisateur ne la possede pas, la section entiere est
// masquee. Toutes les routes de ses items basculent dans
// `disabledRoutes` pour que le middleware front redirige toute
// navigation directe, y compris si l'item n'a pas de permission
// individuelle (la section agit comme un umbrella gate).
$sectionPermission = $section['permission'] ?? null;
if (null !== $sectionPermission && !$this->security->isGranted($sectionPermission)) {
foreach ($section['items'] ?? [] as $item) {
if (isset($item['to'])) {
$disabledRoutes[] = $item['to'];
}
}
continue;
}
$items = [];
foreach ($section['items'] ?? [] as $item) {
$isActive = in_array($item['module'] ?? null, $this->activeModuleIds, true);