fixed initial loging

This commit is contained in:
Vaibhav Surve 2025-10-11 11:42:40 +05:30
parent 706881d08d
commit 7fb5a5217a
4 changed files with 128 additions and 113 deletions

View File

@ -1,6 +1,7 @@
import 'package:flutter/services.dart'; import 'package:flutter/services.dart';
import 'package:url_strategy/url_strategy.dart'; import 'package:url_strategy/url_strategy.dart';
import 'package:firebase_core/firebase_core.dart'; import 'package:firebase_core/firebase_core.dart';
import 'package:marco/helpers/services/storage/local_storage.dart'; import 'package:marco/helpers/services/storage/local_storage.dart';
import 'package:marco/helpers/services/app_logger.dart'; import 'package:marco/helpers/services/app_logger.dart';
import 'package:marco/helpers/services/auth_service.dart'; import 'package:marco/helpers/services/auth_service.dart';
@ -20,7 +21,7 @@ Future<void> initializeApp() async {
]); ]);
await _setupDeviceInfo(); await _setupDeviceInfo();
await _handleAuthTokens(); await _handleAuthTokens();
await _setupTheme(); await _setupTheme();
await _setupFirebaseMessaging(); await _setupFirebaseMessaging();
@ -38,23 +39,10 @@ Future<void> initializeApp() async {
} }
} }
Future<void> _handleAuthTokens() async {
final refreshToken = await LocalStorage.getRefreshToken();
if (refreshToken?.isNotEmpty ?? false) {
logSafe("🔁 Refresh token found. Attempting to refresh JWT...");
final success = await AuthService.refreshToken();
if (!success) {
logSafe("⚠️ Refresh token invalid or expired. User must login again.");
}
} else {
logSafe("❌ No refresh token found. Skipping refresh.");
}
}
Future<void> _setupUI() async { Future<void> _setupUI() async {
setPathUrlStrategy(); setPathUrlStrategy();
await SystemChrome.setEnabledSystemUIMode(SystemUiMode.edgeToEdge); await SystemChrome.setEnabledSystemUIMode(SystemUiMode.edgeToEdge);
logSafe("💡 UI setup completed with default system behavior."); logSafe("💡 UI setup completed.");
} }
Future<void> _setupFirebase() async { Future<void> _setupFirebase() async {
@ -77,6 +65,19 @@ Future<void> _setupDeviceInfo() async {
logSafe("📱 Device Info: ${deviceInfoService.deviceData}"); logSafe("📱 Device Info: ${deviceInfoService.deviceData}");
} }
Future<void> _handleAuthTokens() async {
final refreshToken = LocalStorage.getRefreshToken();
if (refreshToken?.isNotEmpty ?? false) {
logSafe("🔁 Refresh token found. Attempting refresh...");
final success = await AuthService.refreshToken();
if (!success) {
logSafe("⚠️ Refresh failed — user must login again.");
}
} else {
logSafe("❌ No refresh token — skipping refresh.");
}
}
Future<void> _setupTheme() async { Future<void> _setupTheme() async {
await ThemeCustomizer.init(); await ThemeCustomizer.init();
logSafe("💡 Theme customizer initialized."); logSafe("💡 Theme customizer initialized.");
@ -84,10 +85,10 @@ Future<void> _setupTheme() async {
Future<void> _setupFirebaseMessaging() async { Future<void> _setupFirebaseMessaging() async {
await FirebaseNotificationService().initialize(); await FirebaseNotificationService().initialize();
logSafe("💡 Firebase Messaging initialized."); logSafe("💬 Firebase Messaging initialized.");
} }
void _finalizeAppStyle() { void _finalizeAppStyle() {
AppStyle.init(); AppStyle.init();
logSafe("💡 AppStyle initialized."); logSafe("🎨 AppStyle initialized.");
} }

View File

@ -12,20 +12,15 @@ import 'package:marco/helpers/services/storage/local_storage.dart';
Future<void> main() async { Future<void> main() async {
WidgetsFlutterBinding.ensureInitialized(); WidgetsFlutterBinding.ensureInitialized();
// Initialize logging system // --- Logging setup ---
await initLogging(); await initLogging();
logSafe("App starting..."); logSafe("🚀 App starting...");
// Ensure local storage is ready before enabling remote logging
await LocalStorage.init(); await LocalStorage.init();
logSafe("💡 Local storage initialized (early init for logging).");
// Now safe to enable remote logging
enableRemoteLogging(); enableRemoteLogging();
try { try {
await initializeApp(); await initializeApp();
logSafe("App initialized successfully."); logSafe("App fully initialized");
runApp( runApp(
ChangeNotifierProvider( ChangeNotifierProvider(

View File

@ -2,26 +2,29 @@ import 'package:flutter/material.dart';
import 'package:get/get.dart'; import 'package:get/get.dart';
import 'package:marco/helpers/services/auth_service.dart'; import 'package:marco/helpers/services/auth_service.dart';
import 'package:marco/helpers/services/tenant_service.dart'; import 'package:marco/helpers/services/tenant_service.dart';
import 'package:marco/view/auth/forgot_password_screen.dart'; // Auth
import 'package:marco/view/auth/login_screen.dart'; import 'package:marco/view/auth/login_screen.dart';
import 'package:marco/view/auth/login_option_screen.dart';
import 'package:marco/view/auth/register_account_screen.dart'; import 'package:marco/view/auth/register_account_screen.dart';
import 'package:marco/view/auth/forgot_password_screen.dart';
import 'package:marco/view/auth/reset_password_screen.dart'; import 'package:marco/view/auth/reset_password_screen.dart';
import 'package:marco/view/error_pages/coming_soon_screen.dart'; import 'package:marco/view/auth/mpin_screen.dart';
import 'package:marco/view/error_pages/error_404_screen.dart'; import 'package:marco/view/auth/mpin_auth_screen.dart';
import 'package:marco/view/error_pages/error_500_screen.dart'; // Dashboard + Modules
import 'package:marco/view/dashboard/dashboard_screen.dart'; import 'package:marco/view/dashboard/dashboard_screen.dart';
import 'package:marco/view/tenant/tenant_selection_screen.dart';
import 'package:marco/view/Attendence/attendance_screen.dart'; import 'package:marco/view/Attendence/attendance_screen.dart';
import 'package:marco/view/taskPlanning/daily_task_planning.dart'; import 'package:marco/view/taskPlanning/daily_task_planning.dart';
import 'package:marco/view/taskPlanning/daily_progress_report.dart'; import 'package:marco/view/taskPlanning/daily_progress_report.dart';
import 'package:marco/view/employees/employees_screen.dart'; import 'package:marco/view/employees/employees_screen.dart';
import 'package:marco/view/auth/login_option_screen.dart';
import 'package:marco/view/auth/mpin_screen.dart';
import 'package:marco/view/auth/mpin_auth_screen.dart';
import 'package:marco/view/directory/directory_main_screen.dart'; import 'package:marco/view/directory/directory_main_screen.dart';
import 'package:marco/view/expense/expense_screen.dart'; import 'package:marco/view/expense/expense_screen.dart';
import 'package:marco/view/document/user_document_screen.dart'; import 'package:marco/view/document/user_document_screen.dart';
import 'package:marco/view/tenant/tenant_selection_screen.dart'; // Error
import 'package:marco/view/error_pages/coming_soon_screen.dart';
import 'package:marco/view/error_pages/error_404_screen.dart';
import 'package:marco/view/error_pages/error_500_screen.dart';
/// Middleware to enforce authentication and tenant selection
class AuthMiddleware extends GetMiddleware { class AuthMiddleware extends GetMiddleware {
@override @override
RouteSettings? redirect(String? route) { RouteSettings? redirect(String? route) {
@ -38,88 +41,99 @@ class AuthMiddleware extends GetMiddleware {
} }
} }
getPageRoute() { /// Returns the list of all app routes
var routes = [ List<GetPage> getPageRoute() {
final List<GetPage> routes = [
// ========== AUTH ROUTES ==========
GetPage(name: '/auth/login', page: () => LoginScreen()),
GetPage(name: '/auth/login-option', page: () => LoginOptionScreen()),
GetPage(name: '/auth/register_account', page: () => const RegisterAccountScreen()),
GetPage(name: '/auth/forgot_password', page: () => ForgotPasswordScreen()),
GetPage(name: '/auth/reset_password', page: () => const ResetPasswordScreen()),
GetPage(name: '/auth/mpin', page: () => MPINScreen()),
GetPage(name: '/auth/mpin-auth', page: () => MPINAuthScreen()),
// ========== MAIN DASHBOARD ROUTES ==========
GetPage( GetPage(
name: '/', name: '/',
page: () => DashboardScreen(), page: () => DashboardScreen(),
middlewares: [AuthMiddleware()]),
GetPage(
name: '/dashboard',
page: () => DashboardScreen(), // or your actual home screen
middlewares: [AuthMiddleware()], middlewares: [AuthMiddleware()],
), ),
GetPage( GetPage(
name: '/select-tenant', name: '/dashboard',
page: () => const TenantSelectionScreen(), page: () => DashboardScreen(),
middlewares: [AuthMiddleware()]), middlewares: [AuthMiddleware()],
),
GetPage(
name: '/select-tenant',
page: () => const TenantSelectionScreen(),
middlewares: [AuthMiddleware()],
),
// Dashboard // ========== DASHBOARD SUBMODULES ==========
GetPage( GetPage(
name: '/dashboard/attendance', name: '/dashboard/attendance',
page: () => AttendanceScreen(), page: () => AttendanceScreen(),
middlewares: [AuthMiddleware()]), middlewares: [AuthMiddleware()],
),
GetPage( GetPage(
name: '/dashboard', name: '/dashboard/employees',
page: () => DashboardScreen(), page: () => EmployeesScreen(),
middlewares: [AuthMiddleware()]), middlewares: [AuthMiddleware()],
),
GetPage( GetPage(
name: '/dashboard/employees', name: '/dashboard/daily-task-Planning',
page: () => EmployeesScreen(), page: () => DailyTaskPlanningScreen(),
middlewares: [AuthMiddleware()]), middlewares: [AuthMiddleware()],
// Daily Task Planning ),
GetPage( GetPage(
name: '/dashboard/daily-task-Planning', name: '/dashboard/daily-task-progress',
page: () => DailyTaskPlanningScreen(), page: () => DailyProgressReportScreen(),
middlewares: [AuthMiddleware()]), middlewares: [AuthMiddleware()],
),
GetPage( GetPage(
name: '/dashboard/daily-task-progress', name: '/dashboard/directory-main-page',
page: () => DailyProgressReportScreen(), page: () => DirectoryMainScreen(),
middlewares: [AuthMiddleware()]), middlewares: [AuthMiddleware()],
),
GetPage( GetPage(
name: '/dashboard/directory-main-page', name: '/dashboard/expense-main-page',
page: () => DirectoryMainScreen(), page: () => ExpenseMainScreen(),
middlewares: [AuthMiddleware()]), middlewares: [AuthMiddleware()],
// Expense ),
GetPage( GetPage(
name: '/dashboard/expense-main-page', name: '/dashboard/document-main-page',
page: () => ExpenseMainScreen(), page: () => UserDocumentsPage(),
middlewares: [AuthMiddleware()]), middlewares: [AuthMiddleware()],
// Documents ),
// ========== ERROR SCREENS ==========
GetPage( GetPage(
name: '/dashboard/document-main-page', name: '/error/coming_soon',
page: () => UserDocumentsPage(), page: () => ComingSoonScreen(),
middlewares: [AuthMiddleware()]), middlewares: [AuthMiddleware()],
// Authentication ),
GetPage(name: '/auth/login', page: () => LoginScreen()),
GetPage(name: '/auth/login-option', page: () => LoginOptionScreen()),
GetPage(name: '/auth/mpin', page: () => MPINScreen()),
GetPage(name: '/auth/mpin-auth', page: () => MPINAuthScreen()),
GetPage( GetPage(
name: '/auth/register_account', name: '/error/500',
page: () => const RegisterAccountScreen()), page: () => Error500Screen(),
GetPage(name: '/auth/forgot_password', page: () => ForgotPasswordScreen()), middlewares: [AuthMiddleware()],
),
GetPage( GetPage(
name: '/auth/reset_password', page: () => const ResetPasswordScreen()), name: '/error/404',
// Error page: () => Error404Screen(),
GetPage( middlewares: [AuthMiddleware()],
name: '/error/coming_soon', ),
page: () => ComingSoonScreen(),
middlewares: [AuthMiddleware()]),
GetPage(
name: '/error/500',
page: () => Error500Screen(),
middlewares: [AuthMiddleware()]),
GetPage(
name: '/error/404',
page: () => Error404Screen(),
middlewares: [AuthMiddleware()]),
]; ];
// Force uniform transition for all pages
return routes return routes
.map((e) => GetPage( .map(
(e) => GetPage(
name: e.name, name: e.name,
page: e.page, page: e.page,
middlewares: e.middlewares, middlewares: e.middlewares,
transition: Transition.noTransition)) transition: Transition.noTransition,
),
)
.toList(); .toList();
} }

View File

@ -4,7 +4,6 @@ import 'package:flutter_localizations/flutter_localizations.dart';
import 'package:provider/provider.dart'; import 'package:provider/provider.dart';
import 'package:marco/helpers/services/app_logger.dart'; import 'package:marco/helpers/services/app_logger.dart';
import 'package:marco/helpers/extensions/app_localization_delegate.dart';
import 'package:marco/helpers/services/localizations/language.dart'; import 'package:marco/helpers/services/localizations/language.dart';
import 'package:marco/helpers/services/navigation_services.dart'; import 'package:marco/helpers/services/navigation_services.dart';
import 'package:marco/helpers/services/storage/local_storage.dart'; import 'package:marco/helpers/services/storage/local_storage.dart';
@ -16,25 +15,26 @@ import 'package:marco/routes.dart';
class MyApp extends StatelessWidget { class MyApp extends StatelessWidget {
const MyApp({super.key}); const MyApp({super.key});
Future<String> _getInitialRoute() async { Future<String> _resolveInitialRoute() async {
try { try {
final token = LocalStorage.getJwtToken(); final token = LocalStorage.getJwtToken();
if (token == null || token.isEmpty) { if (token == null || token.isEmpty) {
logSafe("User not logged in. Routing to /auth/login-option"); logSafe("👤 No token — going to login option");
return "/auth/login-option"; return "/auth/login-option";
} }
final bool hasMpin = LocalStorage.getIsMpin(); final bool hasMpin = LocalStorage.getIsMpin();
if (hasMpin) { if (hasMpin) {
await LocalStorage.setBool("mpin_verified", false); await LocalStorage.setBool("mpin_verified", false);
logSafe("Routing to /auth/mpin-auth"); logSafe("🔐 MPIN found — going to MPIN auth");
return "/auth/mpin-auth"; return "/auth/mpin-auth";
} }
logSafe("No MPIN. Routing to /dashboard"); logSafe("🏠 Routing to dashboard");
return "/dashboard"; return "/dashboard";
} catch (e, stacktrace) { } catch (e, stacktrace) {
logSafe("Error determining initial route", logSafe("❌ Error resolving initial route",
level: LogLevel.error, error: e, stackTrace: stacktrace); level: LogLevel.error, error: e, stackTrace: stacktrace);
return "/auth/login-option"; return "/auth/login-option";
} }
@ -45,29 +45,35 @@ class MyApp extends StatelessWidget {
return Consumer<AppNotifier>( return Consumer<AppNotifier>(
builder: (_, notifier, __) { builder: (_, notifier, __) {
return FutureBuilder<String>( return FutureBuilder<String>(
future: _getInitialRoute(), future: _resolveInitialRoute(),
builder: (context, snapshot) { builder: (context, snapshot) {
if (snapshot.hasError) { if (snapshot.connectionState == ConnectionState.waiting) {
logSafe("FutureBuilder snapshot error",
level: LogLevel.error, error: snapshot.error);
return const MaterialApp( return const MaterialApp(
home: Center(child: Text("Error determining route")), home: Scaffold(
body: Center(child: CircularProgressIndicator()),
),
); );
} }
if (!snapshot.hasData) { if (snapshot.hasError) {
logSafe("❌ Error while determining initial route: ${snapshot.error}");
return const MaterialApp( return const MaterialApp(
home: Center(child: CircularProgressIndicator()), home: Scaffold(
body: Center(child: Text("Error determining route")),
),
); );
} }
final initialRoute = snapshot.data ?? "/auth/login-option";
logSafe("🚦 Launching app with initial route: $initialRoute");
return GetMaterialApp( return GetMaterialApp(
debugShowCheckedModeBanner: false, debugShowCheckedModeBanner: false,
theme: AppTheme.lightTheme, theme: AppTheme.lightTheme,
darkTheme: AppTheme.darkTheme, darkTheme: AppTheme.darkTheme,
themeMode: ThemeCustomizer.instance.theme, themeMode: ThemeCustomizer.instance.theme,
navigatorKey: NavigationService.navigatorKey, navigatorKey: NavigationService.navigatorKey,
initialRoute: snapshot.data!, initialRoute: initialRoute,
getPages: getPageRoute(), getPages: getPageRoute(),
builder: (context, child) { builder: (context, child) {
NavigationService.registerContext(context); NavigationService.registerContext(context);
@ -76,8 +82,7 @@ class MyApp extends StatelessWidget {
child: child ?? const SizedBox(), child: child ?? const SizedBox(),
); );
}, },
localizationsDelegates: [ localizationsDelegates: const [
AppLocalizationsDelegate(context),
GlobalMaterialLocalizations.delegate, GlobalMaterialLocalizations.delegate,
GlobalWidgetsLocalizations.delegate, GlobalWidgetsLocalizations.delegate,
GlobalCupertinoLocalizations.delegate, GlobalCupertinoLocalizations.delegate,