mirror of
				https://github.com/immich-app/immich.git
				synced 2025-10-31 10:49:11 -04:00 
			
		
		
		
	* WIP: Adding init support for offline-loading * WIP: found bug and fixed with offline browing adv setting * WIP: big some bugs with first login * WIP: static analysis fixes * PR: Removed setting for offline browing * PR: static analysis - remove imports * PR: Refactored user login state * PR: changed logger log level as it happens a lot * PR: change log var to _log * PR: addressing comments * WIP: bug fixes * WIP: static analysis on the logger variable
		
			
				
	
	
		
			45 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
			
		
		
	
	
			45 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
| import 'dart:io';
 | |
| 
 | |
| import 'package:auto_route/auto_route.dart';
 | |
| import 'package:flutter/foundation.dart';
 | |
| import 'package:immich_mobile/routing/router.dart';
 | |
| import 'package:immich_mobile/shared/services/api.service.dart';
 | |
| import 'package:logging/logging.dart';
 | |
| import 'package:openapi/api.dart';
 | |
| 
 | |
| class AuthGuard extends AutoRouteGuard {
 | |
|   final ApiService _apiService;
 | |
|   final _log = Logger("AuthGuard");
 | |
|   AuthGuard(this._apiService);
 | |
|   @override
 | |
|   void onNavigation(NavigationResolver resolver, StackRouter router) async {
 | |
| 
 | |
|     resolver.next(true);
 | |
| 
 | |
|     try {
 | |
|       var res = await _apiService.authenticationApi.validateAccessToken();
 | |
|       if (res == null || res.authStatus != true) {
 | |
|         // If the access token is invalid, take user back to login
 | |
|         _log.fine("User token is invalid. Redirecting to login");
 | |
|         router.replaceAll([const LoginRoute()]);
 | |
|       }
 | |
|     } on ApiException catch (e) {
 | |
|       if (e.code == HttpStatus.badRequest &&
 | |
|           e.innerException is SocketException) {
 | |
|         // offline?
 | |
|         _log.fine(
 | |
|           "Unable to validate user token. User may be offline and offline browsing is allowed.",
 | |
|         );
 | |
|       } else {
 | |
|         debugPrint("Error [onNavigation] ${e.toString()}");
 | |
|         router.replaceAll([const LoginRoute()]);
 | |
|         return;
 | |
|       }
 | |
|     } catch (e) {
 | |
|       debugPrint("Error [onNavigation] ${e.toString()}");
 | |
|       router.replaceAll([const LoginRoute()]);
 | |
|       return;
 | |
|     }
 | |
|   }
 | |
| }
 |