mirror of
				https://github.com/immich-app/immich.git
				synced 2025-10-25 07:52:29 -04:00 
			
		
		
		
	refactor(mobile): use startOAuth and server features flags (#6155)
Co-authored-by: shenlong-tanwen <139912620+shalong-tanwen@users.noreply.github.com>
This commit is contained in:
		
							parent
							
								
									13ba83dce6
								
							
						
					
					
						commit
						2aaf941dda
					
				| @ -11,15 +11,16 @@ class OAuthService { | ||||
|   final log = Logger('OAuthService'); | ||||
|   OAuthService(this._apiService); | ||||
| 
 | ||||
|   Future<OAuthConfigResponseDto?> getOAuthServerConfig( | ||||
|   Future<String?> getOAuthServerUrl( | ||||
|     String serverUrl, | ||||
|   ) async { | ||||
|     // Resolve API server endpoint from user provided serverUrl | ||||
|     await _apiService.resolveAndSetEndpoint(serverUrl); | ||||
| 
 | ||||
|     return await _apiService.oAuthApi.generateOAuthConfig( | ||||
|     final dto = await _apiService.oAuthApi.startOAuth( | ||||
|       OAuthConfigDto(redirectUri: '$callbackUrlScheme:/'), | ||||
|     ); | ||||
|     return dto?.url; | ||||
|   } | ||||
| 
 | ||||
|   Future<LoginResponseDto?> oAuthLogin(String oauthUrl) async { | ||||
|  | ||||
| @ -12,6 +12,7 @@ import 'package:immich_mobile/shared/providers/api.provider.dart'; | ||||
| import 'package:immich_mobile/shared/providers/asset.provider.dart'; | ||||
| import 'package:immich_mobile/modules/login/providers/authentication.provider.dart'; | ||||
| import 'package:immich_mobile/modules/backup/providers/backup.provider.dart'; | ||||
| import 'package:immich_mobile/shared/providers/server_info.provider.dart'; | ||||
| import 'package:immich_mobile/shared/ui/immich_logo.dart'; | ||||
| import 'package:immich_mobile/shared/ui/immich_title_text.dart'; | ||||
| import 'package:immich_mobile/shared/ui/immich_toast.dart'; | ||||
| @ -65,18 +66,18 @@ class LoginForm extends HookConsumerWidget { | ||||
|         isLoadingServer.value = true; | ||||
|         final endpoint = await apiService.resolveAndSetEndpoint(serverUrl); | ||||
| 
 | ||||
|         final loginConfig = await apiService.oAuthApi.generateOAuthConfig( | ||||
|           OAuthConfigDto(redirectUri: serverUrl), | ||||
|         ); | ||||
|         // Fetch and load server config and features | ||||
|         await ref.read(serverInfoProvider.notifier).getServerInfo(); | ||||
| 
 | ||||
|         if (loginConfig != null) { | ||||
|           isOauthEnable.value = loginConfig.enabled; | ||||
|           isPasswordLoginEnable.value = loginConfig.passwordLoginEnabled; | ||||
|           oAuthButtonLabel.value = loginConfig.buttonText ?? 'OAuth'; | ||||
|         } else { | ||||
|           isOauthEnable.value = false; | ||||
|           isPasswordLoginEnable.value = true; | ||||
|         } | ||||
|         final serverInfo = ref.read(serverInfoProvider); | ||||
|         final features = serverInfo.serverFeatures; | ||||
|         final config = serverInfo.serverConfig; | ||||
| 
 | ||||
|         isOauthEnable.value = features.oauthEnabled; | ||||
|         isPasswordLoginEnable.value = features.passwordLogin; | ||||
|         oAuthButtonLabel.value = config.oauthButtonText.isNotEmpty | ||||
|             ? config.oauthButtonText | ||||
|             : 'OAuth'; | ||||
| 
 | ||||
|         serverEndpoint.value = endpoint; | ||||
|       } on ApiException catch (e) { | ||||
| @ -183,11 +184,11 @@ class LoginForm extends HookConsumerWidget { | ||||
|     oAuthLogin() async { | ||||
|       var oAuthService = ref.watch(oAuthServiceProvider); | ||||
|       ref.watch(assetProvider.notifier).clearAllAsset(); | ||||
|       OAuthConfigResponseDto? oAuthServerConfig; | ||||
|       String? oAuthServerUrl; | ||||
| 
 | ||||
|       try { | ||||
|         oAuthServerConfig = await oAuthService | ||||
|             .getOAuthServerConfig(sanitizeUrl(serverEndpointController.text)); | ||||
|         oAuthServerUrl = await oAuthService | ||||
|             .getOAuthServerUrl(sanitizeUrl(serverEndpointController.text)); | ||||
| 
 | ||||
|         isLoading.value = true; | ||||
|       } catch (e) { | ||||
| @ -200,9 +201,8 @@ class LoginForm extends HookConsumerWidget { | ||||
|         return; | ||||
|       } | ||||
| 
 | ||||
|       if (oAuthServerConfig != null && oAuthServerConfig.enabled) { | ||||
|         var loginResponseDto = | ||||
|             await oAuthService.oAuthLogin(oAuthServerConfig.url!); | ||||
|       if (oAuthServerUrl != null) { | ||||
|         var loginResponseDto = await oAuthService.oAuthLogin(oAuthServerUrl); | ||||
| 
 | ||||
|         if (loginResponseDto != null) { | ||||
|           var isSuccess = await ref | ||||
|  | ||||
| @ -2,40 +2,46 @@ import 'package:openapi/api.dart'; | ||||
| 
 | ||||
| class ServerConfig { | ||||
|   final int trashDays; | ||||
|   final String oauthButtonText; | ||||
|   final String externalDomain; | ||||
| 
 | ||||
|   const ServerConfig({ | ||||
|     required this.trashDays, | ||||
|     required this.oauthButtonText, | ||||
|     required this.externalDomain, | ||||
|   }); | ||||
| 
 | ||||
|   ServerConfig copyWith({ | ||||
|     int? trashDays, | ||||
|     String? oauthButtonText, | ||||
|     String? externalDomain, | ||||
|   }) { | ||||
|     return ServerConfig( | ||||
|       trashDays: trashDays ?? this.trashDays, | ||||
|       oauthButtonText: oauthButtonText ?? this.oauthButtonText, | ||||
|       externalDomain: externalDomain ?? this.externalDomain, | ||||
|     ); | ||||
|   } | ||||
| 
 | ||||
|   @override | ||||
|   String toString() => | ||||
|       'ServerConfig(trashDays: $trashDays, externalDomain: $externalDomain)'; | ||||
|       'ServerConfig(trashDays: $trashDays, oauthButtonText: $oauthButtonText, externalDomain: $externalDomain)'; | ||||
| 
 | ||||
|   ServerConfig.fromDto(ServerConfigDto dto) | ||||
|       : trashDays = dto.trashDays, | ||||
|         oauthButtonText = dto.oauthButtonText, | ||||
|         externalDomain = dto.externalDomain; | ||||
| 
 | ||||
|   @override | ||||
|   bool operator ==(Object other) { | ||||
|   bool operator ==(covariant ServerConfig other) { | ||||
|     if (identical(this, other)) return true; | ||||
| 
 | ||||
|     return other is ServerConfig && | ||||
|         other.trashDays == trashDays && | ||||
|     return other.trashDays == trashDays && | ||||
|         other.oauthButtonText == oauthButtonText && | ||||
|         other.externalDomain == externalDomain; | ||||
|   } | ||||
| 
 | ||||
|   @override | ||||
|   int get hashCode => trashDays.hashCode ^ externalDomain.hashCode; | ||||
|   int get hashCode => | ||||
|       trashDays.hashCode ^ oauthButtonText.hashCode ^ externalDomain.hashCode; | ||||
| } | ||||
|  | ||||
| @ -3,40 +3,56 @@ import 'package:openapi/api.dart'; | ||||
| class ServerFeatures { | ||||
|   final bool trash; | ||||
|   final bool map; | ||||
|   final bool oauthEnabled; | ||||
|   final bool passwordLogin; | ||||
| 
 | ||||
|   const ServerFeatures({ | ||||
|     required this.trash, | ||||
|     required this.map, | ||||
|     required this.oauthEnabled, | ||||
|     required this.passwordLogin, | ||||
|   }); | ||||
| 
 | ||||
|   ServerFeatures copyWith({ | ||||
|     bool? trash, | ||||
|     bool? map, | ||||
|     bool? oauthEnabled, | ||||
|     bool? passwordLogin, | ||||
|   }) { | ||||
|     return ServerFeatures( | ||||
|       trash: trash ?? this.trash, | ||||
|       map: map ?? this.map, | ||||
|       oauthEnabled: oauthEnabled ?? this.oauthEnabled, | ||||
|       passwordLogin: passwordLogin ?? this.passwordLogin, | ||||
|     ); | ||||
|   } | ||||
| 
 | ||||
|   @override | ||||
|   String toString() { | ||||
|     return 'ServerFeatures(trash: $trash, map: $map)'; | ||||
|     return 'ServerFeatures(trash: $trash, map: $map, oauthEnabled: $oauthEnabled, passwordLogin: $passwordLogin)'; | ||||
|   } | ||||
| 
 | ||||
|   ServerFeatures.fromDto(ServerFeaturesDto dto) | ||||
|       : trash = dto.trash, | ||||
|         map = dto.map; | ||||
|         map = dto.map, | ||||
|         oauthEnabled = dto.oauth, | ||||
|         passwordLogin = dto.passwordLogin; | ||||
| 
 | ||||
|   @override | ||||
|   bool operator ==(Object other) { | ||||
|   bool operator ==(covariant ServerFeatures other) { | ||||
|     if (identical(this, other)) return true; | ||||
| 
 | ||||
|     return other is ServerFeatures && other.trash == trash && other.map == map; | ||||
|     return other.trash == trash && | ||||
|         other.map == map && | ||||
|         other.oauthEnabled == oauthEnabled && | ||||
|         other.passwordLogin == passwordLogin; | ||||
|   } | ||||
| 
 | ||||
|   @override | ||||
|   int get hashCode { | ||||
|     return trash.hashCode ^ map.hashCode; | ||||
|     return trash.hashCode ^ | ||||
|         map.hashCode ^ | ||||
|         oauthEnabled.hashCode ^ | ||||
|         passwordLogin.hashCode; | ||||
|   } | ||||
| } | ||||
|  | ||||
| @ -26,9 +26,12 @@ class ServerInfoNotifier extends StateNotifier<ServerInfo> { | ||||
|             serverFeatures: const ServerFeatures( | ||||
|               map: true, | ||||
|               trash: true, | ||||
|               oauthEnabled: false, | ||||
|               passwordLogin: true, | ||||
|             ), | ||||
|             serverConfig: const ServerConfig( | ||||
|               trashDays: 30, | ||||
|               oauthButtonText: '', | ||||
|               externalDomain: '', | ||||
|             ), | ||||
|             serverDiskInfo: const ServerDiskInfo( | ||||
| @ -45,10 +48,10 @@ class ServerInfoNotifier extends StateNotifier<ServerInfo> { | ||||
| 
 | ||||
|   final ServerInfoService _serverInfoService; | ||||
| 
 | ||||
|   getServerInfo() { | ||||
|     getServerVersion(); | ||||
|     getServerFeatures(); | ||||
|     getServerConfig(); | ||||
|   Future<void> getServerInfo() async { | ||||
|     await getServerVersion(); | ||||
|     await getServerFeatures(); | ||||
|     await getServerConfig(); | ||||
|   } | ||||
| 
 | ||||
|   getServerVersion() async { | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user