ajout auth guard
This commit is contained in:
41
em2rp/lib/utils/auth_guard_widget.dart
Normal file
41
em2rp/lib/utils/auth_guard_widget.dart
Normal file
@ -0,0 +1,41 @@
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:provider/provider.dart';
|
||||
import 'package:em2rp/providers/user_provider.dart';
|
||||
import 'package:em2rp/views/login_page.dart';
|
||||
|
||||
class AuthGuard extends StatelessWidget {
|
||||
final Widget child;
|
||||
final String?
|
||||
requiredRole; // Si non null, la page est réservée à ce rôle (ex: "ADMIN")
|
||||
|
||||
const AuthGuard({
|
||||
Key? key,
|
||||
required this.child,
|
||||
this.requiredRole,
|
||||
}) : super(key: key);
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
final userProvider = Provider.of<UserProvider>(context);
|
||||
|
||||
// Si l'utilisateur n'est pas connecté (aucun uid ou email)
|
||||
if (userProvider.uid == null || userProvider.email == null) {
|
||||
// Retourne la page de connexion.
|
||||
// Vous pouvez aussi déclencher une redirection automatique si nécessaire.
|
||||
return const LoginPage();
|
||||
}
|
||||
|
||||
// Si la page requiert un rôle spécifique et que l'utilisateur ne le possède pas
|
||||
if (requiredRole != null && userProvider.role != requiredRole) {
|
||||
return Scaffold(
|
||||
appBar: AppBar(title: const Text("Accès refusé")),
|
||||
body: const Center(
|
||||
child: Text("Vous n'êtes pas autorisé à accéder à cette page."),
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
// Sinon, afficher la page demandée
|
||||
return child;
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user