Comptes actifs/inactifs + stats de section dans le tableau de bord
Utilisateurs actifs/inactifs : - Migration : colonne is_active (boolean, default true) sur users - Middleware EnsureUserIsActive : déconnecte les utilisateurs désactivés sur chaque requête - LoginRequest : bloque la connexion si is_active=false (message explicite) - Admin : bouton Activer/Désactiver dans la liste et la page d'édition Protections : impossible de désactiver son propre compte ou le dernier admin actif - Badge « Inactif » + opacité réduite sur la ligne dans la liste admin - Sélection de membres (sources) : filtre is_active=true Sources liées aux sections : - Migration : colonne section_id nullable FK sur sources - Source::section() BelongsTo + Section::sources() HasMany - Formulaire sources/_form : sélecteur de section (sections de l'utilisateur ou toutes pour admin) - SourceController : passe les sections disponibles aux vues create/edit Tableau de bord enrichi (DashboardController) : - Membres et responsables : stats par section (sources par statut, total relevés) compteurs cliquables → liste filtrée, sources récentes de la section - Mes sources assignées (tri par urgence) + mes derniers relevés (inchangés) Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -50,6 +50,15 @@ class LoginRequest extends FormRequest
|
||||
]);
|
||||
}
|
||||
|
||||
if (! Auth::user()->is_active) {
|
||||
Auth::logout();
|
||||
RateLimiter::hit($this->throttleKey());
|
||||
|
||||
throw ValidationException::withMessages([
|
||||
'email' => 'Votre compte est désactivé. Contactez un administrateur.',
|
||||
]);
|
||||
}
|
||||
|
||||
RateLimiter::clear($this->throttleKey());
|
||||
}
|
||||
|
||||
|
||||
@@ -18,6 +18,7 @@ class StoreSourceRequest extends FormRequest
|
||||
'description' => ['nullable', 'string'],
|
||||
'source_type_id' => ['required', 'integer', 'exists:source_types,id'],
|
||||
'depot_id' => ['nullable', 'integer', 'exists:depots,id'],
|
||||
'section_id' => ['nullable', 'integer', 'exists:sections,id'],
|
||||
'lieu_id' => ['nullable', 'integer', 'exists:lieux,id'],
|
||||
'annee_debut' => ['nullable', 'integer', 'min:1000', 'max:2100'],
|
||||
'annee_fin' => ['nullable', 'integer', 'min:1000', 'max:2100', 'gte:annee_debut'],
|
||||
|
||||
@@ -18,6 +18,7 @@ class UpdateSourceRequest extends FormRequest
|
||||
'description' => ['nullable', 'string'],
|
||||
'source_type_id' => ['required', 'integer', 'exists:source_types,id'],
|
||||
'depot_id' => ['nullable', 'integer', 'exists:depots,id'],
|
||||
'section_id' => ['nullable', 'integer', 'exists:sections,id'],
|
||||
'lieu_id' => ['nullable', 'integer', 'exists:lieux,id'],
|
||||
'annee_debut' => ['nullable', 'integer', 'min:1000', 'max:2100'],
|
||||
'annee_fin' => ['nullable', 'integer', 'min:1000', 'max:2100', 'gte:annee_debut'],
|
||||
|
||||
Reference in New Issue
Block a user