1
0
mirror of https://github.com/immich-app/immich.git synced 2025-01-18 16:33:36 +02:00
immich/mobile/lib/routing/auth_guard.dart

47 lines
1.7 KiB
Dart
Raw Normal View History

import 'dart:io';
2022-02-03 18:06:44 +02:00
import 'package:auto_route/auto_route.dart';
import 'package:immich_mobile/routing/router.dart';
import 'package:immich_mobile/shared/models/store.dart';
import 'package:immich_mobile/shared/services/api.service.dart';
import 'package:logging/logging.dart';
import 'package:openapi/api.dart';
2022-02-03 18:06:44 +02:00
class AuthGuard extends AutoRouteGuard {
final ApiService _apiService;
final _log = Logger("AuthGuard");
AuthGuard(this._apiService);
2022-02-03 18:06:44 +02:00
@override
void onNavigation(NavigationResolver resolver, StackRouter router) async {
resolver.next(true);
2022-02-03 18:06:44 +02:00
try {
// Look in the store for an access token
Store.get(StoreKey.accessToken);
// Validate the access token with the server
final 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()]);
2022-02-03 18:06:44 +02:00
}
} on StoreKeyNotFoundException catch (_) {
// If there is no access token, take us to the login page
_log.warning('No access token in the store.');
router.replaceAll([const LoginRoute()]);
return;
} on ApiException catch (e) {
// On an unauthorized request, take us to the login page
if (e.code == HttpStatus.unauthorized) {
_log.warning("Unauthorized access token.");
router.replaceAll([const LoginRoute()]);
return;
}
} catch (e) {
// Otherwise, this is not fatal, but we still log the warning
_log.warning('Error validating access token from server: $e');
2022-02-03 18:06:44 +02:00
}
}
}